postgreSQL备忘
来源:互联网 发布:算法导论 在线 编辑:程序博客网 时间:2024/06/01 08:40
获取今天是周几: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
- postgreSQL备忘
- postgresql 备忘
- PostgreSQL 常用备忘
- PostgreSQL日期函数备忘
- PostgreSQL学习笔记2 - 部分命令备忘
- 【备忘】德哥PostgreSQL 数据库优化 培训视频【18集】
- postgreSQL
- PostgreSQL
- PostgreSQL
- postgresql
- postgresql
- PostgreSQL
- PostgreSQL
- PostgreSQL
- PostgreSQL
- PostgreSQL
- PostgreSQL
- PostGresql
- how to make boot image
- 项目:微会员卡工作笔记
- Android开发之Intent.Action
- 乘法器型号
- 关于数据库的主键。。。
- postgreSQL备忘
- 从属性文件取值
- Spring 事务管理高级应用难点剖析: 第 1 部分
- JFreeChart笔记 (九) 时间序列图:显示多重时间标签文字
- Android实现获取系统应用列表
- Codeforces Round #267 (Div. 2) C. George and Job
- vim多窗口使用技巧
- scroll嵌套listview 计算listview子元素高度 并解决scroll不在顶部问题
- 花生壳内网版原理分析及同类应用