postgresql中的时间戳格式化

2023-12-04 0 702
目录

postgresql时间戳格式化

平时总记不住pg里面怎么将时间戳格式化,记录常用的格式化时间

— 年
select to_char(to_timestamp(1608018517000 / 1000),\’yyyy\’);
— 年-月
select to_char(to_timestamp(1608018517000 / 1000),\’yyyy-MM\’);
— 年-月-日
select to_char(to_timestamp(1608018517000 / 1000),\’yyyy-MM-dd\’);
— 年-月-日 时
select to_char(to_timestamp(1608018517000 / 1000),\’yyyy-MM-dd HH24\’); 对应JAVA 的“yyyy-MM-dd HH”
— 年-月-日 时:分
select to_char(to_timestamp(1608018517000 / 1000),\’yyyy-MM-dd HH24:MI\’);对应JAVA 的“yyyy-MM-dd HH:mm”
— 年-月-日 时:分:秒
select to_char(to_timestamp(1608018517000 / 1000),\’yyyy-MM-dd HH24:MI:SS\’);对应JAVA 的“yyyy-MM-dd HH:mm:ss”

postgresql中时间戳格式转化常识

前提:当数据库中保存的是timestamp类型时,我们需要通过这个时间戳来做乐观数据锁,那么久需要Select出来,然后在更新的时候在Update的where条件中判断时间戳是否与查询时相同。

下面的SQL文查询结果是 "2018-08-20 10:09:10.815125",并且返回类型可以当String处理。返回json等都方便使用。

SQL> select to_char(updateTime, \’yyyy-mm-dd hh24:mi:ss.us\’) from tbl_A;

更新时,参数传入“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')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把字串转换成numericto_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)(第一周从该年的第一天开始)

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 PostgreSQL postgresql中的时间戳格式化 https://www.u-9.cn/database/postgresql/68907.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务