首页 > 解决方案 > 从三个日期列中获取最大日期

问题描述

我需要按 ID 获取三列的最大日期:创建日期、更新日期和交易日期。下面是我引用的数据的简化版本,并不代表我正在使用的实际数据。

+--------------------------------------------------------+
| ID |  Date Created   | Updated Date | Transaction Date |
+--------------------------------------------------------+
| 12 |   19-APR-19     |     NULL     |     20-APR-19    |
| 68 |   02-Nov-18     |   03-DEC-18  |     02-NOV-18    |
| 12 |   05-MAY-19     |   12-MAY-19  |     12-MAY-19    |
| 72 |   10-SEP-19     |   01-OCT-19  |     25-SEP-19    |
+--------------------------------------------------------+

在每个 ID 检索这些列的最大值后,我应该得到:

+---------------------+
| ID |      Date      | 
+---------------------+
| 68 |   03-DEC-18    |   
| 12 |   12-MAY-19    |     
| 72 |   01-OCT-19    |   
+---------------------+

到目前为止,我已经尝试了以下变体:

   CASE WHEN
      TO_CHAR(ud.updated_date,'MM/DD/YYYY') >= TO_CHAR(NVL(mqp.trans_effective_date,0),'MM/DD/YYYY') AND TO_CHAR(ud.updated_date,'MM/DD/YYYY') >= TO_CHAR(NVL(mt.date_created,0),'MM/DD/YYYY') THEN TO_CHAR(ud.updated_date,'MM/DD/YYYY')
      WHEN 
      TO_CHAR(mt.transaction_date,'MM/DD/YYYY') >= TO_CHAR(NVL(ud.updated_date,0),'MM/DD/YYYY') AND TO_CHAR(mt.transaction_date,'MM/DD/YYYY') >= TO_CHAR(NVL(mt.date_created,0),'MM/DD/YYYY') THEN TO_CHAR(mt.transaction_date,'MM/DD/YYYY')
      WHEN
      TO_CHAR(mt.date_created,'MM/DD/YYYY') >= TO_CHAR(NVL(ud.updated_date,0),'MM/DD/YYYY') AND TO_CHAR(mt.date_created,'MM/DD/YYYY') >= TO_CHAR(NVL(mt.transaction_date,0),'MM/DD/YYYY') THEN TO_CHAR(mt.date_created,'MM/DD/YYYY')
  END Date

但这以以下错误结束:

ORA-00932: inconsistent datatypes: expected NLS PARAMETER got DATE
00932. 00000 -  "inconsistent datatypes: expected %s got %s"
*Cause:    
*Action:

我还尝试了以下不同的变体:

  GREATEST(TO_CHAR(mt.date_created,ud.updated_date,mt.transaction_date), 'MM/DD/YYYY') Date

但后来我得到这个错误:

ORA-00932: inconsistent datatypes: expected NLS PARAMETER got DATE
00932. 00000 -  "inconsistent datatypes: expected %s got %s"
*Cause:    
*Action

任何建议将不胜感激!

标签: sqloraclegreatest-n-per-group

解决方案


使用greatest()

select id, greatest(updated_date, mqp.trans_effective_date, mt.date_created)
from . . .

假设所有都是类型date(正如您的问题所暗示的那样),您应该没有转换问题。

如果您在多行上有 id,则使用聚合:

select id, greatest(max(updated_date), max(mqp.trans_effective_date), max(mt.date_created))
from . . .

推荐阅读