Mit postgres 8.4 möchte ich die vorhandene Tabelle aktualisieren:
CREATE TABLE public.dummy
(
address_id SERIAL,
addr1 character(40),
addr2 character(40),
city character(25),
state character(2),
zip character(5),
customer boolean,
supplier boolean,
partner boolean
)
WITH (
OIDS=FALSE
);
Anfangs habe ich meine Abfrage mit der insert-Anweisung getestet:
insert into address customer,supplier,partner
SELECT
case when cust.addr1 is not null then TRUE else FALSE end customer,
case when suppl.addr1 is not null then TRUE else FALSE end supplier,
case when partn.addr1 is not null then TRUE else FALSE end partner
from (
SELECT *
from address) pa
left outer join cust_original cust
on (pa.addr1=cust.addr1 and pa.addr2=cust.addr2 and pa.city=cust.city
and pa.state=cust.state and substring(cust.zip,1,5) = pa.zip )
left outer join supp_original suppl
on (pa.addr1=suppl.addr1 and pa.addr2=suppl.addr2 and pa.city=suppl.city
and pa.state=suppl.state and pa.zip = substring(suppl.zip,1,5))
left outer join partner_original partn
on (pa.addr1=partn.addr1 and pa.addr2=partn.addr2 and pa.city=partn.city
and pa.state=partn.state and pa.zip = substring(partn.zip,1,5) )
where pa.address_id = address_id
Als Neuling kann ich nicht in die Update-Anweisung konvertieren, dh vorhandene Zeilen mit Werten aktualisieren, die von der select-Anweisung zurückgegeben werden. Jede Hilfe wird sehr geschätzt.
sql
postgresql
subquery
sql-update
Stackover
quelle
quelle
Antworten:
Postgres erlaubt:
Diese Syntax ist kein Standard-SQL, aber für diese Art von Abfrage viel praktischer als Standard-SQL. Ich glaube, Oracle akzeptiert (zumindest) etwas Ähnliches.
quelle
ERROR: 42P01: relation "dummy" does not exist
dummy
muss durch den Namen der Tabelle ersetzt werden, die Sie aktualisieren möchten. Bitte verstehen Sie Fragen und Antworten, bevor Sie sich bewerben.Du bist hinter der
UPDATE FROM
Syntax her.Verweise
quelle
Wenn mit einem Join keine Leistungssteigerungen erzielt werden, bevorzuge ich aus Gründen der Lesbarkeit Common Table Expressions (CTEs):
IMHO etwas moderner.
quelle
Es gibt viele Möglichkeiten, die Zeilen zu aktualisieren.
Wenn es um
UPDATE
die Zeilen mit Unterabfragen geht, können Sie einen dieser Ansätze verwenden.Ansatz 4 [Using WITH-Anweisung]
Ich hoffe, das wäre hilfreich. «
quelle
quelle
@Mayur "4.2 [Verwenden einer Abfrage mit komplexem JOIN]" mit Common Table Expressions (CTEs) hat den Trick für mich getan.
Hoffe das hilft ...: D.
quelle