我在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"修改器已经切换,文字必须完全匹配, 没有额外的空白。
*操作:更正格式字符串以匹配文字。
有什么问题?
答案 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
设置的任何内容。对于每个人来说,这不太可能是一样的,所以你不想构建依赖的代码。