postgresql saveOrUpdate实现方式

在postgresql9.5以上 提供了conflict() 来判断sql语句插入时,是否发生重复

1. saveOrUpdate实现方式     主键重复后,执行update操作

INSERT INTO user_pages (user_id, page_id, enabled)
VALUES (1, 1, TRUE)
ON CONFLICT (user_id, page_id)
DO UPDATE SET enabled = 0;

  

2.saveOrNothing    主键重复后,不执行任何操作

INSERT INTO user_pages (user_id, page_id, enabled)
VALUES (1, 1, TRUE)
ON CONFLICT (user_id, page_id)
DO NOTHING

 

postgresql用户手册:

http://www.postgres.cn/docs/9.6/sql-insert.html#SQL-ON-CONFLICT

 

posted @ 2021-01-21 09:25  wangssd  阅读(1048)  评论(0编辑  收藏  举报