• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    postgresql数据库根据年月查询出本月的所有数据操作

    表里的所有数据:

    现在我要根据创建时间的 年月查询 当月所有的数据

    比如前台传给我一个年月的字段planTimeMonth,值为2018-06

    那么我们需要查询创建时间为6月份的所有数据

    sql:

    java代码中sql拼接:

    criteria.andCondition("to_char(crt_time, 'yyyy-mm')='"+query.get("planTimeMonth").toString()+"'");

    补充:postgresql根据周和年计算周对应的时间段

    查询本周星期一的时间

    方法一:

    SELECT current_date +cast(-1*(TO_NUMBER(to_char(DATE (current_date),'D'),'99')-2) ||' days' as interval)

    解析:

    TO_NUMBER 将一个字符串转换成数字

    格式:TO_NUMBER(string,format)

    -- 一周里的日子(1-7;周日是1)

    select to_char(CURRENT_DATE ,'D')

    DDD 一年里的日子(001-366)

    DD 一个月里的日子(01-31)

    D 一周里的日子(1-7;周日是1)

    -- 将得到的字符串转换成数字
    select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')
    
    -- 因为得到的星期一为2,所以要减去2
    select TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2
    
    -- 将得到的数字乘以 -1 比如例子中:-1*3 就是 -3 ,也就是减去 3天
    select cast(-1*3 || 'days' as interval) 
    
    -- 就是将当天减去0天 得到了星期一的日期
    select cast(-1*0 || 'days' as interval) + CURRENT_DATE
    
    SELECT  to_char(CURRENT_DATE +cast(-1*(TO_NUMBER(to_char(CURRENT_DATE,'D'),'99')-2) ||' days' as interval),'yyyy-mm-dd');
    

    方法二:

    select  to_char('2019-09-27'::date - (  case when EXTRACT(DOW FROM TIMESTAMP '2019-09-27') = 0 then 6 
         when EXTRACT(DOW FROM TIMESTAMP '2019-09-27') = 1 then 0 
         else EXTRACT(DOW FROM TIMESTAMP '2019-09-27') -1
         end )::integer,'yyyy-mm-dd') as 星期一日期 
         ,to_char('2019-09-27'::date + (   case when EXTRACT(DOW FROM TIMESTAMP '2019-09-27') = 0 then 0 
         else 7- EXTRACT(DOW FROM TIMESTAMP '2019-09-27')
         end )::integer,'yyyy-mm-dd') 星期日日期

    获取某时间是星期几

    select extract(DOW FROM cast('2019-04-23' as TIMESTAMP))

    根据年份和周数计算所在周的时间段

    select  to_char(cast(-1*(TO_NUMBER(to_char(to_date('2019'||'-01-01','yyyy-mm-dd'),'D'),'99')-2)|| 'days' as interval) + to_date('2019'||'-01-01','yyyy-mm-dd'),'yyyy-mm-dd') 在2019年1月1日所属星期的星期一日期
    , to_char(to_date(cast(-1*(TO_NUMBER(to_char(to_date('2019'||'-01-01','yyyy-mm-dd'),'D'),'99')-2)|| 'days' as interval) + to_date('2019'||'-01-01','yyyy-mm-dd'),'yyyy-mm-dd')
    +cast(38*7|| 'days' as interval),'yyyy-mm-dd') 第38周的开始时间
    , to_char(to_date(cast(-1*(TO_NUMBER(to_char(to_date('2019'||'-01-01','yyyy-mm-dd'),'D'),'99')-2)|| 'days' as interval) + to_date('2019'||'-01-01','yyyy-mm-dd'),'yyyy-mm-dd')
    +cast(38*7+6|| 'days' as interval),'yyyy-mm-dd') 第38周的结束时间
    

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • 查询PostgreSQL占多大内存的操作
    • Postgresql通过查询进行更新的操作
    • postgresql 实现查询某时间区间的所有日期案例
    • PostgreSQL 分页查询时间的2种比较方法小结
    • postgresql通过索引优化查询速度操作
    • postgresql查询锁表以及解除锁表操作
    • Postgresql 实现查询一个表/所有表的所有列名
    • PostgreSQL 实现查询表字段信息SQL脚本
    上一篇:Postgresql 实现查询一个表/所有表的所有列名
    下一篇:postgresql查询锁表以及解除锁表操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    postgresql数据库根据年月查询出本月的所有数据操作 postgresql,数据库,根据,年月,