过程、函数里面不能直接使用ddl语句,可以借助动态sql来实现,如:
execute immediate 'create table xx (a varchar2(10),b int)';
不需要事先定义字段名、表名,当然也可用变量来存储表名或整个建表语句.
execute immediate 'create table xx (a varchar2(10),b int)';
不需要事先定义字段名、表名,当然也可用变量来存储表名或整个建表语句.
解决方案 »
- oracle中两个游标同时打开运行,两个游标值是一一对应?请问咋写?
- oracle 语句执行多次结果不相同,请高手帮忙
- 请问怎么通过SQL 转换这样的日期格式?
- 急急急,请教一个巨难的sql
- 紧急求助:一个有关jdbc 和 存储过程的问题。
- oracle安装后环境变量配置问题
- 求ORACLE开发入门的书
- 请问查询全部表信息的sql语句怎么写
- 这样的SQL语句怎么写?
- [ORA-00600: internal error code, arguments: [qctbyt : bfc]
- *** 紧急求助:熟悉ERP/MRPII(尤其是 Oracle Application R11i)接口的哥们进来指点一二 ***
- "slect * from tableName select @@ROWCOUNT as DataRowCount"在oracle 中怎么写!!
str varchar(2000);
begin
str :='create table'||table_name||'(a varchar2 not null, ........)';
-----动态构造CREATE语句
execute immediate str;---执行SQL语句
//用存储过程来创建表,如果该表存在就删除他,然后创建新表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权限
sybase里的零时表不同session看不见各自的表
而oracle里面的零时表是不同session不能互见表数据,但是表是可以互见的所以我建议你,零时表还是在外面建立,存储过程里不要建零时表,不然一个:表存在会报错,还有一个:会导致存储过程效率很低
as
str varchar2(100);
begin
str:='CREATE GLOBAL TEMPORARY TABLE TABLENAME (
COL1 VARCHAR2(10),
COL2 NUMBER
) ON COMMIT PRESERVE ROWS';
execute immediate str;
end;
/