动态SQL创建表为什么会报“ORA-00901: invalid CREATE command”

动态SQL创建表为什么会报“ORA-00901: invalid CREATE command”

问题描述:

declare
table_name varchar2(20);
field1 varchar2(20);
datatype1 varchar2(20);
str_sql varchar2(500);

begin
table_name := 'sem_108';
field1 := 'id';
datatype1 := 'number(2)';
str_sql := 'create table'||''|| table_name ||'('|| field1 ||''|| datatype1 ||')';
dbms_output.put_line(str_sql);
execute immediate str_sql;
end;
/
如题,为什么以上语句会报“ORA-00901: invalid CREATE command”错误?

你字符串拼错了**注意空格**。正确的:

'create table '|| table_name ||' ( '|| field1 ||' '|| datatype1 ||' )'

str_sql := 'create table'||''|| table_name ||'('|| field1 ||''|| datatype1 ||')';
下断点,看看拼接的sql语句有没有问题。

那就加一个
select str_sql
看看输出什么

oracle可以单步执行的 也可以在后面加上异常处理 你报错的意思就是创建提交失败