SORU
6 HAZİRAN 2011, PAZARTESİ


PostgreSQL sorgu kullanarak güncelleştirmek tablo satırları

PostgreSQL 8.4, amacım varolan bir tabloyu güncelleştirmek için kullanma

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
);

Başlangıçta benim sorgu ınsert deyimi kullanarak test ettim:

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

olmak update deyimi yani. için, dönüştürme başarısız oluyorum Acemi değerleri select deyimi tarafından döndürülen satır güncelleme ile mevcut. Herhangi bir yardım çok takdir.

CEVAP
6 HAZİRAN 2011, PAZARTESİ


İsim verir

UPDATE dummy
SET customer=subquery.customer,
    address=subquery.address,
    partn=subquery.partn
FROM (SELECT address_id, customer, address, partn
      FROM  /* big hairy SQL */ ...) AS subquery
WHERE dummy.address_id=subquery.address_id;

Bu sözdizimi, standart SQL değil, ama standart SQL sorgu daha bu tür için daha uygundur. Oracle (en az) benzer kabul düşünüyorum.

Bunu Paylaş:
  • Google+
  • E-Posta
Etiketler:

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • Arun Kumar

    Arun Kumar

    18 Mart 2010
  • Awesomesauce Network

    Awesomesauce

    4 EKİM 2012
  • Pepsi

    Pepsi

    1 Kasım 2005