當前位置:首頁 » 存儲配置 » oracle存儲過程建表

oracle存儲過程建表

發布時間: 2022-08-04 08:46:46

⑴ oracle存儲過程中建表

首先根據需求,想好需要建哪些欄位,哪些是主鍵,建在哪個表空間下,另外欄位類型也要考慮好,因為一旦建成表往裡面插入數據後,欄位類型就不容易更改了
表建成之後,如果數據量很大,應該考慮建立針對某欄位的索引。

⑵ 如何在Oracle的存儲過程中建表啊

可以在存儲過程中使用execute immediate 'sql';子句來創建表,例如Execute Immediate 'create table test(id int)';

⑶ oracle存儲過程創建表

CREATE OR REPLACE PROCEDURE list_xs_name as
str_sql varchar2(2000);
begin
str_sql := 'create global temporary table xs_name (xh int,name varchar2(255),kc varchar2(255),fs int) on commit preserve rows';
execute immediate str_sql;
str_sql := 'select * from xs_name';
execute immediate str_sql;
dbms_output.put_line(str_sql);
END;

⑷ oracle 存儲過程建表

這個過程就行了。。
create or replace procere wym
authid current_user
is
vn_ctn number(2);
begin
select count(*) into vn_ctn from user_all_tables a where a.table_name like upper('invbasdoc');
if vn_ctn > 0 then
execute immediate 'drop table invbasdoc';
end if;
execute immediate 'create table invbasdoc as select * from test_abcd';
end ;

原來的過程中:execute immediate 'drop table invbasdoc'; 當如果資料庫中不存在這張表的時候就會報錯的。。
上面是對資料庫中是否存在表進行了判斷,因此能夠避免「表不存在」這樣的錯誤。。

⑸ ORACLE存儲過程創建臨時表並插入數據。

存儲過程創建表後,在編譯階段資料庫中並沒有該表。這時向表中插入數據,會提示表不存在。所以,插入語句要賦值到變數里,通過e來執行。

⑹ 想用oracle的存儲過程動態建表

建立序列:
create sequence t_id
increment by 1
start with 1
nomaxvalue
cache 20;
建立自動建表過程:
create or replace procere pro_createtable(tname in varchar2 default to_char(sysdate,'yyyymm'))
as
v_sql varchar2(200);
v_tname varchar2(10);
begin
if length(tname)<>6 then
raise_application_error(-20000,'輸入參數長度不夠,不能轉換為日期格式!');
end if ;
if to_number(substr(tname,5,2)) not between 1 and 12 then
raise_application_error(-20001,'輸入參數中不包含有效的月份數字,不能轉換為日期格式!');
end if ;
--v_tname:=to_char(to_date(tname,'yyyymm'),'yyyymm');
v_tname:='hd_'||tname;
v_sql:='create table '||v_tname||' ('||
'id number not null,'||
'name varchar2(20),'||
'city varchar2(20))'||
'tablespace users';
execute immediate v_sql;
end;
測試:
begin
pro_createtable;
pro_createtable('201106');
pro_createtable('201115');--報錯
end;

⑺ 如何在oracle中使用存儲過程創建表,如果存在就先刪除

沒有許可權?具體點 或者貼圖!
不過應該是沒有create table和drop table的許可權吧,你試試賦下給此用戶看看

⑻ ORACLE存儲過程中,可以動態創建表么

需要用到動態sql。
1、首先要給用戶賦予許可權:
grant create any table to 用戶名;
2、創建存儲過程:
create procere p_create_table
(v_sql varchar2)--輸入建表語句
as
begin
execute immediate v_sql;
end;
3、執行:

⑼ oracle如何用存儲過程建表

說的不明白
1.建什麼樣的表?
2.欄位是怎麼樣的變數?
3.表內的數據怎麼來?僅僅是一個表嗎?

參數是怎麼來的?輸入的參數還是按照日期來的?
變數名是怎麼來的?手動輸入的欄位名參數還是怎麼?
我看你就把你想做什麼說出來,你這樣沒法弄
----------------------------------------------------------------------
PROCEDURE SP_CREATE_new_table
(
on_flag OUT NUMBER,
out_reason OUT VARCHAR2
)
is
v_sql1 varchar2(2000);
v_a varchar2(1);
v_b varchar2(1);
v_c varchar2(1);

begin

select 'a' into v_a from al;
select 'b','c' into v_b,v_c from al;

v_sql1 :='create table '||v_a||'('||v_b||' varchar2(1),'||v_c||' varchar2(1))';
EXECUTE IMMEDIATE v_sql1;

commit;

EXCEPTION
WHEN OTHERS
THEN
on_flag := SQLCODE;
out_reason := SUBSTR (SQLERRM, 1, 255);
ROLLBACK;
END;

有什麼看不懂的就問吧
運行後,執行select * from a;
表名就叫a,欄位名叫b和c,都是按你說的

⑽ ORACLE 存儲過程如何實現動態建表或者是觸發器

需求沒說清楚,你說建立的新表有什麼需求?什麼叫每插入一條記錄都會自動添加匹配的其他三表的欄位值? 你在新表插數據和舊表有什麼關系?新表的欄位不是你自己定義的?去和什麼匹配

熱點內容
廣東gps時鍾伺服器雲主機 發布:2024-10-05 08:27:31 瀏覽:754
超級訪問沙溢 發布:2024-10-05 08:26:13 瀏覽:226
php刪除數組空 發布:2024-10-05 08:15:21 瀏覽:465
100平小型超市如何配置 發布:2024-10-05 08:10:56 瀏覽:91
sql語句刪除多表 發布:2024-10-05 08:10:55 瀏覽:818
nosql資料庫對比 發布:2024-10-05 08:05:46 瀏覽:943
androidlollipop 發布:2024-10-05 07:40:38 瀏覽:699
買es200哪個配置性價比 發布:2024-10-05 07:33:03 瀏覽:554
linux分區方案 發布:2024-10-05 07:21:51 瀏覽:854
小說分銷系統源碼 發布:2024-10-05 07:13:54 瀏覽:633