Postgresql,根据另一列添加(年,月或日)到目前为止

Postgresql,根据另一列添加(年,月或日)到目前为止,第1张

概述我需要一个来自8.4 POSTGRESQL数据库的查询来列出我所订购的所有产品,该日期代表产品保修结束的实际日期. 表格是这样的,我会简单的说: PRODUCT (varchar) WARRANTY (int)TYPE_WARRANTY (char) ( 'Y', 'M', 'D' ) -- Years, Months or DaysCREATED_AT (date) 举个例子: PRODU 我需要一个来自8.4 POSTGREsql数据库的查询来列出我所订购的所有产品,该日期代表产品保修结束的实际日期.

表格是这样的,我会简单的说:

PRODUCT (varchar) WARRANTY (int)TYPE_WARRANTY (char) ( 'Y','M','D' ) -- Years,Months or DaysCREATED_AT (date)

举个例子:

PRODUCT  |  WARRANTY  |  TYPE_WARRANTY  |  CREATED_AT ------------------------------------------------------'PROD A' |      1     |       'Y'       | '2014-01-01''PROD B' |     10     |       'M'       | '2014-06-01''PROD C' |     30     |       'D'       | '2014-01-01'

我需要的是一个查询,它将带给我这个:

PRODUCT  |  WARRANTY  |  TYPE_WARRANTY  |  CREATED_AT  | WARRANTY_ENDS | DAYS-----------------------------------------------------------------------------'PROD C' |    30      |       'D'       | '2014-01-01' | '2014-01-31'  | -175'PROD A' |     1      |       'Y'       | '2014-01-01' | '2015-01-01'  | 160'PROD B' |    10      |       'M'       | '2014-06-01' | '2015-04-01'  | 250

我希望你能理解它

所以我需要的是选择所有产品并在保修期结束时订购,包括今天和该日期之间的天数.

我已经拥有的东西:

我知道如何获取日期,我知道如何将日期添加到日期,我现在需要的是一种使查询理解我想根据type_warranty列的值添加间隔的方法.

我在这里使用’1年’作为例子并且它有效但我需要它像“1个月”和“1天”一样动态地工作.

SELECT   PRODUCT,WARRANTY,TYPE_WARRANTY,CREATED_AT,(CREATED_AT + (WARRANTY * '1 year'::INTERVAL)) as WARRANTY_ENDS,EXTRACT(day from age((CREATED_AT + '1 year',current_date)) as daysFROM tableorder by days;

这是有效的,但只有多年,当然,我不知道如何将’1年’转换为’1个月’或’1天’,具体取决于warranty_type

你有什么想法可以提供帮助吗?

解决方法 我现在没有安装Postgresql 8.4,但这有用吗?

SELECT    PRODUCT,(CREATED_AT + (WARRANTY *        CASE TYPE_WARRANTY            WHEN 'Y' THEN '1 year'::interval            WHEN 'M' THEN '1 month'::interval            WHEN 'D' THEN '1 day'::interval        END    ))::date as WARRANTY_ENDS,(created_at + (warranty * itvalue))::date - current_date as days    FROM table;
总结

以上是内存溢出为你收集整理的Postgresql,根据另一列添加(年,月或日)到目前为止全部内容,希望文章能够帮你解决Postgresql,根据另一列添加(年,月或日)到目前为止所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1160131.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存