MySql 和 PostgreSQL 数据库 根据一张表update另一张表数据

今天在写代码的过程中遇到一个问题,就是需要用一张表的数据去更新另一张表某个字段,由于本人之前常用的是MySQL数据库,记得可以通过join的方式更新。结果发现 postgre数据库竟然不可以,所以特意记录一下两种数据库,更新数据的脚本

1:MySQL脚本

UPDATE TABLE A JOIN table2 b ON A.busid = b.busid 
SET A.district = b.district;

2:PostgreSQL脚本

  ①、单列

UPDATE TABLE A 
	SET ( district ) = ( SELECT district FROM table2 b WHERE A.site = b.site ) 
WHERE
	bustype = 1;

②、多列

UPDATE TABLE A 
	SET ( column01, colum02, column03 ) = (
SELECT
	b.column01, b.column02,
	b.column03 
FROM
	table2 b 
WHERE
	A.COLUMN = b.COLUMN)

③ 、定义行号,删除重复数据

DELETE 
FROM
    tableA 
WHERE
    ID IN (
SELECT ID 
FROM
    ( SELECT ROW_NUMBER () OVER ( PARTITION BY column01, column02 ), ID FROM tableA ) AS T 
WHERE
    T.ROW_NUMBER > 1 
    );

 

posted @ 2021-08-18 10:22  徐徐图之  阅读(1356)  评论(0编辑  收藏  举报