尝试 select * from ext_poc
时收到以下错误
ORA-29913:执行ODCIEXTTABLEOPEN标注时出错ORA-29400:数据盒式磁带错误KUP-00554:解析访问参数时遇到错误KUP-01005:语法错误:找到“标识符”:期待以下之一:“binary_double,binary_float,逗号, char,date,defaultif,decimal,double,float,integer,(no,nullif,oracle_date,oracle_number,position,raw,recnum,),unsigned,varrawc,varchar,varraw,varcharc,zoned“KUP-01008:bad标识符为:varchar2 KUP-01007:第4行第10栏29913. 00000 - “执行%s标注时出错”*原因:执行指定的标注导致错误 . *操作:检查错误消息采取适当的措施 .
下面是表的 ddl
:
CREATE TABLE "JDASTG"."EXT_POC"
( "ID" varchar2(100),
"NAME" varchar2(100),
"DOB" varchar2(100)
)
ORGANIZATION EXTERNAL
( TYPE ORACLE_LOADER
DEFAULT DIRECTORY "SCPO_EXT_DATA"
ACCESS PARAMETERS
( RECORDS DELIMITED BY NEWLINE
FIELDS TERMINATED BY ','
MISSING FIELD VALUES ARE NULL
(id varchar2(100),
name varchar2(100),
dob varchar2(100)
)
)
LOCATION
( 'xyz_aldrin.csv'
)
);
PS:如果 varchar2(100)
更改为 char(100)
,则不会发生此错误:
MISSING FIELD VALUES ARE NULL
(id char(100),
name char(100),
dob char(100)
)
1 回答
区分表中指定的oracle内部数据类型和外部表(sqlldr的控制文件)的访问参数中指定的外部数据类型非常重要 . 请记住,再次阅读manual . 它应该变得清晰 . SQL加载器中允许CHAR,而VARCHAR2则不允许