过程、函数里面不能直接使用ddl语句,可以借助动态sql来实现,如:
execute immediate 'create table xx (a varchar2(10),b int)';
不需要事先定义字段名、表名,当然也可用变量来存储表名或整个建表语句.

解决方案 »

  1.   

    这种方式可以吗?在建立表的时候,如a这样字段是不是在开始的时候定义?在过程、函数里面不能直接使用ddl语句,需要动态的来创建
    str  varchar(2000);
    begin
    str :='create table'||table_name||'(a varchar2 not null,   ........)';
    -----动态构造CREATE语句
    execute immediate str;---执行SQL语句
      

  2.   

    可以给你一个例子
    //用存储过程来创建表,如果该表存在就删除他,然后创建新表create or replace procedure create_user_login --没有参数,这里不要括弧
    IS
      i INTEGER;
    BEGIN SELECT COUNT(*) INTO i FROM user_tables where table_name=Upper('user_login') ;
     
    if i > 0 then
       EXECUTE IMMEDIATE 'drop table user_login';
    end if;
    EXECUTE immediate 'create table user_login
    (id        integer primary key,
     name      varchar2(20),
     sex       varchar2(4),
     office_id integer,
     bussiness varchar2(100),
     tele      varchar2(20),
     pirror_id integer,
     photo     long raw,
     password  varchar2(20),
     regist_date date,
     invalid_date date)';
    END;
    -- EXISTS 只能用在SQL语句中
    -- tablename需转换成大写,否则查询不到
    -- 用EXECUTE IMMEDIATE语句须用户有EXECUTE权限
      

  3.   

    oracle里面的零时表和sybase的不一样,
    sybase里的零时表不同session看不见各自的表
    而oracle里面的零时表是不同session不能互见表数据,但是表是可以互见的所以我建议你,零时表还是在外面建立,存储过程里不要建零时表,不然一个:表存在会报错,还有一个:会导致存储过程效率很低
      

  4.   

    create procedure pro
    as
    str varchar2(100);
    begin
    str:='CREATE GLOBAL TEMPORARY TABLE TABLENAME (
       COL1  VARCHAR2(10),
       COL2  NUMBER
    ) ON COMMIT PRESERVE ROWS';
    execute immediate str;
    end;
    /