如何获取PostgreSQL中两个日期之间的季度数?

时间:2018-09-06 07:02:51

标签: sql postgresql date-arithmetic

我具有MS SQL函数DATEDIFF

SELECT DATEDIFF(QQ, 0, '2018-09-05')

返回474(整数)。

PostgreSQL的等效功能是什么?

3 个答案:

答案 0 :(得分:3)

MSSQL 0'1900-01-01'中的日期DATEDIFF(QQ, 0, '2018-09-05'),该函数将从QUARTER1900-01-01获得2018-09-05的数量

但是PostgreSQL没有QUARTER数字函数。

您可以尝试使用

  1. EXTRACT(QUARTER FROM TIMESTAMP '2018-09-05')获得本月的QUARTER号。

  2. date_part('year',age('2018-09-05','1900-01-01'))获取之间的年份 '2018-09-05''1900-01-01'

然后做一些计算。

select (EXTRACT(QUARTER FROM TIMESTAMP '2018-09-05') + 
      date_part('year',age('2018-09-05','1900-01-01')) * 4) -1 QUARTER

Results

| quarter |
|---------|
|     474 |

答案 1 :(得分:1)

我认为当前接受的是不正确的。

例如如果您将日期“ 1900-01-01”更改为“ 2017-07-01”,则实际上会得到 6 季度差异。

  • 但预期结果应为:
    • 包括第一季度和最后一个季度:5
    • 排除第一季度和最后一个季度:3
    • 排除上个季度:4
    select 
        age('2018-09-05','2017-07-01') age,
        (EXTRACT(QUARTER FROM TIMESTAMP '2018-09-05') + 
      date_part('year',age('2018-09-05','2017-07-01')) * 4) -1 QUARTER

结果:

age                 |quarter|
--------------------|-------|
1 year 2 mons 4 days|      6|

原因是age('2018-09-05','2017-07-01')返回1 year 2 mons 4 days(可能超过12个月)。


我用来计算季度数的答案:

with params as (
    select 
        '2017-07-01 00:00:00'::timestamp date_from,
        '2018-09-05 00:00:00'::timestamp date_to
)
select      
    extract( quarter from date_from)::int date_from_quarter,
    (extract( quarter from date_to))::int date_to_quarter,
    age(date_to, date_from) date_diff,
    (extract(year from date_to) - extract(year from date_from))::int how_many_yr,
    -- exclude begin and end
    (extract(year from date_to) - extract(year from date_from))::int* 4 - extract( quarter from date_from)::int + (extract( quarter from date_to))::int - 1 quarter_diff,
    -- exclude begin quarter 
    (extract(year from date_to) - extract(year from date_from))::int* 4 - extract( quarter from date_from)::int + (extract( quarter from date_to))::int quarter_diff_include_current_quarter
    from params
;

结果:

date_from_quarter|date_to_quarter|date_diff           |how_many_yr|quarter_diff|quarter_diff_include_current_quarter|
-----------------|---------------|--------------------|-----------|------------|------------------------------------|
                3|              3|1 year 2 mons 4 days|          1|           3|                                   4|

答案 2 :(得分:0)

在Postgres上比较复杂:

( (DATE_PART('year',  '2018-09-05') - DATE_PART('year', '1900-01-01')) * 12 
   + (DATE_PART('month',  '2018-09-05') - DATE_PART('month', '1900-01-01'))
) / 4

其他资源:topic