[英]ORA-01858: a non-numeric character was found where a numeric was expected?
[英]Seeing ORA-01858: a non-numeric character was found where a numeric was expected
以下是我对 Oracle SQL Developer 的查询:
INSERT INTO ENROLLMENTS (DATE,PARTNER_NAME,ENROLLMENTS)
SELECT TO_CHAR(TS, 'DD-MON-YYYY HH AM') AS DATE, mrch_bnft_cd, COUNT(*)
FROM ENROLLMENTS
WHERE TS > trunc(sysdate-1/24, 'HH') + 5/24
AND TS < trunc(sysdate, 'HH') + 5/24
GROUP BY TO_CHAR(TS, 'DD-MON-YYYY HH AM'), mrch
ORDER BY TO_CHAR(TS, 'DD-MON-YYYY HH AM'), mrch_bnft
我得到一个错误
ORA-01858: 在预期为数字错误的位置发现了非数字字符
但错误没有告诉我在哪里。 有任何想法吗?
DATE = TIMESTAMP(6)
TS = TIMESTAMP(6)
PARTNER = VARCHAR2(35 BYTE)
ENROLLMENTS = NUMBER
MRCH_BNFT= VARCHAR2(35 BYTE)
基本上,您试图在时间戳字段中存储一个表示日期的字符串。 如果您更换:
TO_CHAR(TS, 'DD-MON-YYYY HH AM')
经过
TRUNC(TS, 'hh24')
在所有 4 个地方它都应该工作。
INSERT INTO ENROLLMENTS (DATE,PARTNER_NAME,ENROLLMENTS)
SELECT TRUNC(TS, 'hh24') AS DATE, mrch_bnft_cd, COUNT(*)
FROM ENROLLMENTS
WHERE TS > trunc(sysdate-1/24, 'HH') + 5/24
AND TS < trunc(sysdate, 'HH') + 5/24
GROUP BY TRUNC(TS, 'hh24'), mrch
ORDER BY TRUNC(TS, 'hh24'), mrch_bnft
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.