新聞中心
在oracle里面怎么循環(huán)??
要使用pl/sql塊
創(chuàng)新互聯(lián)專注于網(wǎng)站建設(shè)|成都企業(yè)網(wǎng)站維護|優(yōu)化|托管以及網(wǎng)絡(luò)推廣,積累了大量的網(wǎng)站設(shè)計與制作經(jīng)驗,為許多企業(yè)提供了網(wǎng)站定制設(shè)計服務(wù),案例作品覆蓋宣傳片制作等行業(yè)。能根據(jù)企業(yè)所處的行業(yè)與銷售的產(chǎn)品,結(jié)合品牌形象的塑造,量身策劃品質(zhì)網(wǎng)站。
采用
loop
語句
exit when 退出循環(huán)的條件
end loop
Oracle中循環(huán)語句的幾種用法
--1.For
FOR?循環(huán)變量?IN?[REVERSE]?下界..上界
LOOP
語句組
END?LOOP;
--計算5的階乘,并在屏幕上打印出來。
DECLARE
num?NUMBER(3):=5;
resu?NUMBER(3):=1;
BEGIN
for?i?in?1..num?loop
resu:=?resu?*?i;
end?loop;
dbms_output.put_line(TO_CHAR(resu));
END;
--2.WHILE循環(huán)
語法格式:
WHILE?條件?LOOP
語句組
END?LOOP;
--用WHILE循環(huán)求1~100所有整數(shù)的和?
DECLARE
summ?number?:=0;
i?number(3):=100;
BEGIN
WHILE?i0?LOOP
summ:=summ+i;
i:=i?-?1;
END?LOOP;
dbms_output.put_line(summ);
END;
oracle 循環(huán)語句
create table temp_tab
(
id number primary key not null,
name varchar2(50) not null,
age number not null
);
declare
ids number(30) :=0;
names varchar2(50) :='卡卡';
age number(30) :=5;
begin
for i in 1..15 loop
ids :=ids+1;
age :=age+1;
insert into temp_tab values(ids,names,age);
end loop;
end;
Oracle存儲過程游標for循環(huán)怎么寫
首先編寫存儲過程的整體結(jié)構(gòu),如下:
create or replace procedure test_proc is
v_date date; --變量定義
begin
select sysdate into v_date from dual;
end test_proc;
2
定義游標:
create or replace procedure test_proc is
v_date date; --定義變量
cursor cur is select * from ldcode; --定義游標
begin
select sysdate into v_date from dual;
end test_proc;
3
編寫for循環(huán):
create or replace procedure test_proc is
v_date date; --定義變量
cursor cur is select * from ldcode where rownum10; --定義游標
begin
select sysdate into v_date from dual;
--游標for循環(huán)開始
for temp in cur loop --temp為臨時變量名,自己任意起
Dbms_Output.put_line(temp.Code); --輸出某個字段,使用"變量名.列名"即可。
end loop;
--游標for循環(huán)結(jié)束
end test_proc;
4
測試運行,點擊【DBMS Output】標簽頁查看結(jié)果如下圖:
END
二、帶參數(shù)的游標for循環(huán)
1
定義帶參數(shù)的游標:
cursor cur(v_codetype ldcode.Codetype%TYPE) is
select * from ldcode where codetype = v_codetype; --定義游標
定義游標格式:
cursor 游標名稱(變量定義) is 查詢語句;
注意:
where條件中的變量名v_codetype要與游標定義cur(v_codetype ldcode.Codetype%TYPE)中的一致。
2
編寫for循環(huán)部分:
--游標for循環(huán)開始
for temp in cur('llmedfeetype') loop
--temp為臨時變量名,自己任意起
--cur('llmedfeetype')為"游標名稱(傳入的變量)"
Dbms_Output.put_line(temp.Code); --輸出某個字段,使用"變量名.列名"即可。
end loop;
--游標for循環(huán)結(jié)束
3
測試運行,點擊【DBMS Output】標簽頁查看結(jié)果如下圖:
Oracle中使用PL/SQL怎樣用循環(huán)插入多條數(shù)據(jù)?
使用loop循環(huán),比如:
for item in (select a,b,c from table_a where 條件) loop
insert into table_b(a,b,c) values (item.a,item.b,item.c);
end loop;
也可以使用索引表循環(huán),以上只是一個簡單的例子,需要根據(jù)你的具體情況選擇循環(huán)方式。
1、采用insert into values 語句插入一條,寫很多條語句即可多條數(shù)據(jù),這種主要針對于離散值以及一些基礎(chǔ)信息的錄入,如:insert into test(xh,mc) values('123','測試');
如果插入的數(shù)據(jù)有規(guī)律,可利用for、loop循環(huán)插入,主要用于批量生成測試數(shù)據(jù)
begin
for i in 1 .. 100 loop
insert into test(xh,mc) values(i||'','測試');
end loop;
end ;。
2、采用insert into selct from 語句來一次性插入一個集合,這種主要依據(jù)于要插入的數(shù)據(jù)源已經(jīng)存儲于數(shù)據(jù)庫對象中,或者利用dual虛表來構(gòu)造數(shù)據(jù),經(jīng)過加工后寫入一個集合。
insert into test (xh,mx) select '123','測試' from dual;
3、采用plsql等工具、或者oracle的imp、impdp命令來導(dǎo)入,這種主要用數(shù)據(jù)庫與數(shù)據(jù)庫之間的大批量數(shù)據(jù)導(dǎo)入,導(dǎo)入的數(shù)據(jù)格式為plsql的pde、oracle的dmp等。dmp文件可使用
table_exists_action參數(shù)控制導(dǎo)入動作:replace替換原表,truncate清除原表數(shù)據(jù)再導(dǎo)入,append增量導(dǎo)入數(shù)據(jù),當(dāng)然impdp數(shù)據(jù)泵的導(dǎo)入要依賴于directory路徑。
impdp 用戶名/密碼 dumpfile=123.dmp logfile=123.log directory=imp_dir tables=test table_exists_action=append。
4、使用excel文件直接拷貝。這種主要用于要寫入的數(shù)據(jù)已是excel文件或者行列分明的其它格式文件,每一列的值和表結(jié)構(gòu)相對應(yīng),可直接打開表的行級鎖,把數(shù)據(jù)拷貝進入。
請教大神,oracle數(shù)據(jù)庫循環(huán)語句怎么寫
你想要的這幾個結(jié)果,都可以直接使用SQL語句查出,無需循環(huán)。
Oracle循環(huán)實在PLSQL塊中編寫:關(guān)鍵字for XXX loop 循環(huán)體 end loop;
網(wǎng)站題目:oracle怎么循環(huán)語句,oracle循環(huán)語句sql怎么寫
文章源于:http://ef60e0e.cn/article/dscscei.html