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

 

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...