postgreSQL备忘

获取今天是周几:extract(DOW FROM now())

获取今天是这个月的第几天:extract(DAY FROM now())

三周前:select now() - interval '3 week';

一天前:select current_date - 1

null值转换函数:COALESCE(num,0)

多条变一条:select groupid,string_agg(deviceid::text,','::text) from vms_store_group_devices group by groupid;

一条变多条(xml): select (unnest(xpath('/map/zh/text()',name))) from goods_list

一条变多条(逗号分隔的):SELECT r.id,UNNEST(string_to_array(r.device_list,','))::INTEGER as device_id FROM vms_check_records r

日期时间戳转换为long型毫秒数:SELECT EXTRACT(EPOCH FROM TIMESTAMP  '2014-07-25 10:05:21')

把long型秒数转换为时间戳类型:TO_TIMESTAMP(1405057985000/1000);//如果是毫秒数请除以1000

添加大于0的约束:alter table vms_device_stock add constraint check_more_than_zero check(goods_num >= 0);

触发器函数:

CREATE OR REPLACE FUNCTION update_device_stock() RETURNS TRIGGER  AS $BODY$

DECLARE

deviceid integer;

BEGIN

SELECT d.device_id INTO deviceid FROM vms_device_stock d WHERE d.device_id = NEW.device_id AND delete_flag = 0;

IF deviceid ISNULL THEN INSERT INTO vms_device_stock (device_id,goods_id,goods_num) VALUES (NEW.device_id,NEW.goods_id,NEW.change_num) ;

ELSE UPDATE vms_device_stock SET goods_num = (goods_num + NEW.change_num) WHERE device_id = NEW.device_id AND goods_id

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值