好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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)

?

1

2

3

4

5

6

7

8

9

10

11

12

13

-- 将得到的字符串转换成数字

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' );

方法二:

?

1

2

3

4

5

6

7

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))

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

?

1

2

3

4

5

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周的结束时间

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

原文链接:https://blog.csdn.net/weixin_39702323/article/details/80678808

查看更多关于postgresql数据库根据年月查询出本月的所有数据操作的详细内容...

  阅读:38次