承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

PostgreSQL COALESCE使用方法代码解析

管理员 2023-06-25 08:19:15 互联网圈 6 ℃ 0 评论 1988字 收藏

PostgreSQL COALESCE使用方法代码解析

有这类要求,更新自己本身的字段的某个值进行加或减

常规方法:

UPDATE
tbl_kintai_print_his
SET
print_time = now(),
print_emp_cd = ‘000000’,
times = (select times from tbl_kintai_print_his where kokyaku_cd = ‘000002’ AND
sagyo_ymd = ‘2015-01⑶0’ )
+ 1,
pattern = ‘055’ ,
ko_item_1 = ‘no.0’ ,
ko_item_2 = ‘no.2’ ,
ko_item_3 = ‘no.3’ ,
ko_item_4 = ‘no.4’ ,
ko_item_5 = ‘no.5’
WHERE
kokyaku_cd = ‘000002’ AND
sagyo_ymd = ‘2015-01⑶0’

能实现,不过效力肯定不高,要进行查询两次

pgsql里面提供一个函数能完成这个操作:

UPDATE
tbl_kintai_print_his
SET
print_time = now(),
print_emp_cd = ‘000000’,
times = COALESCE (SUM(times),0)+ 1,
pattern = ‘055’ ,
ko_item_1 = ‘no.0’ ,
ko_item_2 = ‘no.2’ ,
ko_item_3 = ‘no.3’ ,
ko_item_4 = ‘no.4’ ,
ko_item_5 = ‘no.5’
WHERE
kokyaku_cd = ‘000002’ AND
sagyo_ymd = ‘2015-01⑶0’

能直接取到上一次的结果进行添加

二:还有一种用法就是在几个字段中取值,从前往后,一直取到不为NULL的值为止。

select id , name ,coalesce(Ph_no,Alt_no,Office_no) as contact number from employee

我们可以通过这样的语句,来得到Ph_no,Alt_no,Office_no这几个字段中,第一个不存在null的数值,上面的语句得到

本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!

文章来源:丸子建站

文章标题:PostgreSQL COALESCE使用方法代码解析

https://www.wanzijz.com/view/59025.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信