在Oracle PL / SQL

时间:2015-09-16 15:11:42

标签: sql string oracle date literals

我在Oracle PL / SQL中有一个查询,它根据客户名称给出一个有序列表,基于账单的百分比,他们延迟支付。查询如下

With date_check AS
    (Select *
        From tblBills
        Where Pay_Date Between CAST('2015-09-01' AS DATE) And CAST('2015-09-30' AS DATE)
    )
    Select ddo.CODE As "Customer Name",
      100.0 * ROUND(Cast(Count(fpp.ID) AS FLOAT)  / 
      ( Select Count(fpp2.ID)
        From date_check fpp2 
        Join tblMethods dppm2
         On fpp2.PAY_METHOD = dppm2.ID
        Where dppm2.IS_DELAYED = 'Y'), 2) As "% Delay"
    From date_check fpp
      Join tblMethods dppm On fpp.PAYMENT_METHOD_ID = dppm.ID
      Join tblCustomers ddo On fpp.CUSTOMER_ID = ddo.ID
    Where dppm.IS_DELAYED = 'Y'
    Group By ddo.CODE
    Order By Count(fpp.ID) Desc

当我运行此查询时,我收到以下异常:

  

ORA-01861:文字与格式字符串
不匹配   01861. 00000 - "文字与格式字符串不匹配"
  *原因:输入中的文字必须与文字中的文字长度相同              格式字符串(前导空格除外)。如果              " FX"修改器已经切换,文字必须完全匹配,              没有额外的空白。
  *操作:更正格式字符串以匹配文字。

有什么问题?

1 个答案:

答案 0 :(得分:4)

使用日期文字

Where Pay_Date Between date '2015-09-01' And date '2015-09-30'

或使用带有显式格式掩码的to_date函数将字符串转换为日期

Where Pay_Date Between to_date('2015-09-01', 'YYYY-MM-DD') And 
                       to_date('2015-09-30', 'YYYY-MM-DD')

直接cast将使用当前会话的nls_date_format设置的任何内容。对于每个人来说,这不太可能是一样的,所以你不想构建依赖的代码。