无法确定“ORA-00922:缺少或无效选项”错误的原因

Unable to determine the cause of the "ORA-00922: missing or invalid option" error

提问人:cmomah 提问时间:1/30/2021 最后编辑:cmomah 更新时间:2/5/2021 访问量:4487

问:

当我尝试运行 Talend 作业以将数据从 Oracle 脚本加载到数据库表时,出现“ORA-00922: missing or invalid option”错误

脚本本身已经过测试,并在 Oracle SQL 编辑器和 Talend 中成功运行

有谁知道为什么我在 Talend 中运行加载作业时可能会收到错误?

在互联网上快速查找此错误显示:

ORA-00922:如果在定义存储子句或列时指定了无效选项,则会出现选项缺失或无效。Oracle 提供有关此错误的以下信息:

原因: 指定列的有效选项不是 NULL 指定列不能包含任何 NULL 值。只有约束才能遵循数据类型。在 DATE 或 LONG 数据类型上指定最大长度也会导致此错误。

如果我们可以暂时假设错误来自 SCHEMA,那么有人认为这个架构有什么问题吗?

  • “Column”和“Type”列属于数据源:Oracle SQL 脚本
  • “DB Column”(数据库列)和 “DB Type”(数据库类型)列属于 Oracle DB 表,数据应加载到该表中

enter image description here

下面是直接从 Oracle 获取的目标表的定义。表名称为 Payments

enter image description here

目标表已存在。当我直接在表中运行插入脚本时,首先我收到消息:命令行错误:6 列:17 错误报告 - SQL 错误:ORA-00984:此处不允许列。第 6 行第 17 列的项目恰好是程序代码。

当我在程序代码的值(以及日期值)周围加上引号时,插入工作。正在填充不可为 null 的字段,如果我尝试将 NULL 插入到不可为 null 的字段中,则会显示相应的错误消息

下面是一个有效的插入脚本:

INSERT INTO PAYMENTS 
(CLAIMANT_ID, CLAIM_ID, PROGRAM_CODE, BWE_DATE, PROCESS_DATE, DEPOSIT_DATE,
GROSS_AMOUNT,CLAIMANT_NET_AMOUNT, FEDERAL_TAXES, STATE_LOCAL_TAXES, OP_OFFSET, 
 OOS_OP_OFFSET, CHILD_SUPPORT, OOS_CS, FPUC, LWA)
VALUES
(123456,54321,'ABC','24-OCT-20','01-JAN-21','04-JAN-21',149,128,15,6,0,0,0,0,0,0)
Oracle 语法错误 架构 Talend

评论

0赞 Littlefoot 1/30/2021
我不认识 Talend。但是,如果删除日期模式会发生什么?
0赞 cmomah 1/30/2021
我刚刚试过。没有区别。仍然显示相同的错误
0赞 Marmite Bomber 1/30/2021
唯一的机会:尝试在日志中的某处找到该语句,看看出了什么问题。祝你好运!create table
0赞 NickW 1/30/2021
该 Oracle 错误非常通用,因此在尝试调试问题时不是很有帮助。目标表是否已存在,或者您的 Talend 任务正在创建它?如果它不存在,请尝试直接在 Oracle 中创建它并再次运行 Talend 作业。如果该表已存在,则检查不可为 null 的列是否全部填充到 Talend 任务中
0赞 cmomah 1/30/2021
@marmite轰炸机,我不确定该怎么做,但我会和我们的 DBA 核实一下

答:

2赞 cmomah 2/5/2021 #1

感谢您的帮助,错误原因已确定。我在脚本的末尾加了一个分号(就像你编写SQL查询时通常会做的那样)。但在 Talend 中,整个脚本以双引号开头和结尾。脚本后面不能有分号,然后以双引号结尾。删除分号后,错误就消失了

enter image description here