PostgreSQL数据库中如何从update返回old
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,这篇文章主要讲解了"PostgreSQL数据库中如何从update返回old",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"PostgreSQL数据库中
千家信息网最后更新 2025年01月22日PostgreSQL数据库中如何从update返回old
这篇文章主要讲解了"PostgreSQL数据库中如何从update返回old",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"PostgreSQL数据库中如何从update返回old"吧!
UPDATE tbl xSET tbl_id = 23 , name = 'New Guy'FROM tbl y -- using the FROM clauseWHERE x.tbl_id = y.tbl_id -- must be UNIQUE NOT NULLAND x.tbl_id = 3RETURNING y.tbl_id AS old_id, y.name AS old_name , x.tbl_id , x.name;
old_id | old_name | tbl_id | name--------+----------+--------+--------- 3 | Old Guy | 23 | New Guy
WITH sel AS (
SELECT tbl_id, name FROM tbl WHERE tbl_id = 3 -- assuming unique tbl_id ), upd AS ( UPDATE tbl SET name = 'New Guy' WHERE tbl_id = 3 RETURNING tbl_id, name )SELECT s.tbl_id AS old_id, s.name As old_name , u.tbl_id, u.nameFROM sel s, upd u;
UPDATE tbl xSET tbl_id = 24 , name = 'New Gal'FROM (SELECT tbl_id, name FROM tbl WHERE tbl_id = 4 FOR UPDATE) y WHERE x.tbl_id = y.tbl_idRETURNING y.tbl_id AS old_id, y.name AS old_name, x.tbl_id, x.name;对于 insert 怎么办呢 ?
WITH sel AS ( SELECT id, title FROM posts WHERE id IN (1,2) -- select rows to copy ), ins AS ( INSERT INTO posts (title) SELECT title FROM sel RETURNING id, title )SELECT ins.id, sel.id AS from_idFROM insJOIN sel USING (title);If title is not unique per query (but at least id is unique per table):WITH sel AS ( SELECT id, title, row_number() OVER (ORDER BY id) AS rn FROM posts WHERE id IN (1,2) -- select rows to copy ORDER BY id ), ins AS ( INSERT INTO posts (title) SELECT title FROM sel ORDER BY id -- ORDER redundant to be sure RETURNING id )SELECT i.id, s.id AS from_idFROM (SELECT id, row_number() OVER (ORDER BY id) AS rn FROM ins) iJOIN sel s USING (rn);This second query relies on the undocumented implementation detail that rows are inserted in the order provided. It works in all current versions of Postgres and is probably not going to break.留着做参考吧 .
感谢各位的阅读,以上就是"PostgreSQL数据库中如何从update返回old"的内容了,经过本文的学习后,相信大家对PostgreSQL数据库中如何从update返回old这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
数据
数据库
学习
内容
就是
怎么办
思路
情况
文章
更多
知识
知识点
篇文章
跟着
问题
参考
实践
推送
研究
验证
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
fifa16数据库怎么用
数据库动态防御技术
上海现代软件开发注意事项
腾讯未来互联网科技城
中国水稻数据库中心育龙59
郑州苹果软件开发
天津网络技术开发
宁波快易通网络技术有限公司
opc服务器 编程
幽宝可梦服务器
nist物联网网络安全标准
c 包含数据库怎么打包
智能服务器巡检管理系统
像素工厂里面怎么加入服务器
深圳星城软件开发公司
闵行区网络营销软件开发代理商
openkm数据库
乡网络安全责任制检查考核制度
电脑数据库文件大小
数据库讲座
计算机网络安全文献信息
数据库分组查询是怎么分组
请求数据失败服务器内部错误
点亮服务器端口
南宁网络安全保障有口皆碑
软件开发毕设任务书
为什么软件开发用think
服务器安全狗修复漏洞失败
excel如何导入dbc数据库
dnf服务器出现错误