PostgreSQL中的时间格式转化常识
下⾯的SQL⽂查询结果是 “2018-08-20 10:09:10.815125”,并且返回类型可以当String处理。返回json等都⽅便使⽤。
SQL>SELECT to_char(current_timestamp,'YYYY-MM-DD HH24:MI:SS');
更新时,参数传⼊“2018-08-20 10:09:10.815125”的字符串,那么需要在SQL中转化来匹配updateTime字段的timeStamp数据类型。
SQL>update tbl_A set username='XXX'where userid='001'and updateTime = to_timestamp('2018-08-20 10:09:10.815125','yyyy-mm-dd hh24:mi:ss.us');函数 返回类型 描述 例⼦
to_char(timestamp,text)text把时间戳转换成字串 to_char(current_timestamp,'HH12:MI:SS')
to_char(interval,text)text把时间间隔转为字串 to_char(interval'15h 2m 12s','HH24:MI:SS')
to_char(int,text)text把整数转换成字串 to_char(125,'999')
to_char(double precision,text)text把实数/双精度数转换成字串 to_char(125.8::real,'999D9')
unix时间戳转换日期格式to_char(numeric,text)text把numeric转换成字串 to_char(-125.8,'999D99S')
to_date(text,text)date把字串转换成⽇期 to_date('05 Dec 2000','DD Mon YYYY')
to_timestamp(text,text)timestamp把字串转换成时间戳 to_timestamp('05 Dec 2000','DD Mon YYYY')
to_timestamp(double)timestamp把UNIX纪元转换成时间戳 to_timestamp(200120400)
to_number(text,text)numeric把字串转换成numeric to_number('12,454.8-','99G999D9S')
模式 描述
HH ⼀天的⼩时数(01-12)
HH12 ⼀天的⼩时数(01-12)
HH24 ⼀天的⼩时数(00-23)
MI 分钟(00-59)
SS 秒(00-59)
MS 毫秒(000-999)
US 微秒(000000-999999)
AM 正午标识(⼤写)
Y,YYY 带逗号的年(4和更多位)
YYYY 年(4和更多位)
YYY 年的后三位
YY 年的后两位
Y 年的最后⼀位
MONTH 全长⼤写⽉份名(空⽩填充为9字符)
Month 全长混合⼤⼩写⽉份名(空⽩填充为9字符)
month 全长⼩写⽉份名(空⽩填充为9字符)
MON ⼤写缩写⽉份名(3字符)
Mon 缩写混合⼤⼩写⽉份名(3字符)
mon ⼩写缩写⽉份名(3字符)
MM ⽉份号(01-12)
DAY 全长⼤写⽇期名(空⽩填充为9字符)
Day 全长混合⼤⼩写⽇期名(空⽩填充为9字符)
day 全长⼩写⽇期名(空⽩填充为9字符)
DY 缩写⼤写⽇期名(3字符)
Dy 缩写混合⼤⼩写⽇期名(3字符)
dy 缩写⼩写⽇期名(3字符)
DDD ⼀年⾥的⽇⼦(001-366)
DD ⼀个⽉⾥的⽇⼦(01-31)
D ⼀周⾥的⽇⼦(1-7;周⽇是1)
W ⼀个⽉⾥的周数(1-5)(第⼀周从该⽉第⼀天开始)
WW ⼀年⾥的周数(1-53)(第⼀周从该年的第⼀天开始)
计算相差天数
select date_part('day','2015-01-15 17:05'::timestamp-'2013-01-14 16:05'::timestamp);
在PostgreSQL中可以直接对时间进⾏加减运算:、
SELECT now()::timestamp+'1 year';--当前时间加1年
SELECT now()::timestamp+'1 month';--当前时间加⼀个⽉
SELECT now()::timestamp+'1 day';--当前时间加⼀天
SELECT now()::timestamp+'1 hour';--当前时间加⼀个⼩时
SELECT now()::timestamp+'1 min';--当前时间加⼀分钟
SELECT now()::timestamp+'1 sec';--加⼀秒钟
select now()::timestamp+'1 year 1 month 1 day 1 hour 1 min 1 sec';--加1年1⽉1天1时1分1秒SELECT now()::timestamp+(col ||' day')::interval FROM table--把col字段转换成天然后相加
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论