thefansofjay
thefansofjay
采纳率61.9%
2015-12-07 09:48 阅读 8.6k

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

1

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”错误?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

4条回答 默认 最新

  • 已采纳
    Team77 DV2 2015-12-08 07:19

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

    'create table '|| table_name ||' ( '|| field1 ||' '|| datatype1 ||' )'
    
    点赞 1 评论 复制链接分享
  • caozhy 从今以后生命中的每一秒都属于我爱的人 2015-12-07 09:51

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

    点赞 1 评论 复制链接分享
  • caozhy 从今以后生命中的每一秒都属于我爱的人 2015-12-07 09:55

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

    点赞 1 评论 复制链接分享
  • qq_21462475 虚心学习请教 2015-12-08 13:39

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

    点赞 评论 复制链接分享

相关推荐