Postgres에서는 하위 쿼리를 사용하여 각 행에 대해 원하는 값을 검색함으로써 테이블 행에 대한 업데이트를 수행할 수 있습니다. 이를 달성하는 한 가지 방법은 다음 구문을 사용하는 것입니다.
UPDATE table_name SET column_name = (SELECT value FROM subquery WHERE subquery_condition) WHERE table_condition;
포스트그레스 8.4 데이터베이스의 더미 테이블을 업데이트하여 고객, 공급업체 및 파트너 열을 채우는 것이 목표인 다음 예를 고려해 보세요. 하위 쿼리에서 파생된 값 사용:
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 ); UPDATE dummy SET customer = (SELECT CASE WHEN cust.addr1 IS NOT NULL THEN TRUE ELSE FALSE END), supplier = (SELECT CASE WHEN suppl.addr1 IS NOT NULL THEN TRUE ELSE FALSE END), partner = (SELECT CASE WHEN partn.addr1 IS NOT NULL THEN TRUE ELSE FALSE END) 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 SUBSTR(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 = SUBSTR(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 = SUBSTR(partn.zip,1,5) ) WHERE pa.address_id = address_id;
이 쿼리는 더미 테이블의 각 행에 대한 고객, 공급업체 및 파트너 열을 효과적으로 업데이트하여 설정합니다. 해당 주소가 cust_original, supp_original 및 Partner_original 테이블에 있으면 TRUE로, 그렇지 않으면 FALSE로 설정됩니다.
이 구문은 표준 SQL은 아니지만 하위 쿼리에서 파생된 값을 기반으로 테이블 행을 업데이트하는 데 편리함을 제공합니다. Postgres에서.
위 내용은 하위 쿼리를 사용하여 Postgres 테이블 행을 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!