温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

postgresql中的时间戳格式化怎么写

发布时间:2023-03-21 09:54:07 来源:亿速云 阅读:103 作者:iii 栏目:开发技术

今天小编给大家分享一下postgresql中的时间戳格式化怎么写的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

    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 hh34: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 hh34: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)(第一周从该年的第一天开始)

    以上就是“postgresql中的时间戳格式化怎么写”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI