使用postgres 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
);

最初,我使用insert语句测试了我的查询:

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

作为新手,我无法转换为update语句,即使用select语句返回的值更新现有行.

推荐答案

Postgres允许:

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;

这种语法不是标准的SQL,但对于这种类型的查询,它比标准SQL方便得多.我相信甲骨文(至少)也接受了类似的观点.

Sql相关问答推荐

在SQL中对字符串进行逻辑排序,将数字部分排序为数字值

查询多个表并返回合并在联合列上的所有表中的所有行

无效和不匹配的计数

在SQL中将相同且紧挨着的元素进行分组

SQL基于多个值 Select 单行

查找表中特定值的上次更新日期

判断序列索引处的序列是否完整

按分类标准检索记录

仅当交叉应用返回单值时才更新记录

在SELECT中将日期格式转换为双周时段

如何在AWS Athena中 Select JSON数组的最后一个元素?

此过程如何在不引用传递的参数值的情况下执行工作?

SQL仅返回第一个字母在A-Z之间的值

同时插入和更新记录

Snowflake 中的分层数据

当我返回 sql 列时,有没有办法只反转数字? ( hebrew )

比使用NOT EXISTS更高效的SQL删除方法是什么?

Clob 问题 - 将 clob 列拆分为多行

HIVE SQL where 子句未按预期工作

使用其他表 SUM 的交换价格转换价格并获得 AVG