所以我创建了一个Oracle数据库架构,我试图插入数据但是出现以下错误
SQL Error: ORA-00984: column not allowed here
00984. 00000 - "column not allowed here"
这是表格的DDL
CREATE TABLE "SAMPLE_TYPE"
(
"SAMPLE_TYPE_ID" NUMBER(10,0) NOT NULL,
"SAMPLE_CODE" VARCHAR2(20) NOT NULL,
CONSTRAINT SAMPLE_TYPE_PK PRIMARY KEY ("SAMPLE_TYPE_ID")
);
--------------------------------------------------------
-- DDL for Sequence SEQ_SAMPLE_TYPE
--------------------------------------------------------
CREATE SEQUENCE "SEQ_SAMPLE_TYPE" MINVALUE 1 MAXVALUE 999999999999999999999999999 INCREMENT BY 1 START WITH 61 CACHE 20 NOORDER NOCYCLE ;
最后这里是失败的插入语句。
INSERT INTO "SAMPLE_TYPE" (SAMPLE_TYPE_ID, SAMPLE_CODE) VALUES (SEQ_SAMPLE_TYPE.nextval, "Small");
有关如何纠正此问题的任何想法?谢谢!
答案 0 :(得分:5)
Oracle sql中的字符串由单引号分隔。您使用了双引号,因此Oracle认为您正在创建别名。当您双引号表名时,还必须确保使用创建表时使用的完全相同的大小写。这是一个简化版本
INSERT INTO SAMPLE_TYPE
(SAMPLE_TYPE_ID, SAMPLE_CODE)
VALUES
(SEQ_SAMPLE_TYPE.nextval, 'Small');