问题描述
- 动态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可以单步执行的 也可以在后面加上异常处理 你报错的意思就是创建提交失败
时间: 2024-07-31 21:47:02