国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

批處理 動態(tài)sql

2024-08-31 00:59:40
字體:
供稿:網(wǎng)友
1.
DECLARE
TYPE ref_cursor_type IS ref CURSOR;
v_mycursor ref_cursor_type;
TYPE id_list IS TABLE OF integer;
TYPE name_list IS TABLE OF varchar2(30);
v_tabid id_list:=id_list();
v_tabname name_list:=name_list();
sql_str varchar2(200);
BEGIN
--查詢所以行,放在集合里
sql_str:='select empno,ename from emp';
sql_str:=sql_str||' order by empno desc';
execute immediate sql_str BULK COLLECT INTO v_tabid,v_tabname;
FOR c IN v_tabid.first..v_tabid.last LOOP
dbms_output.put_line('empno為'||v_tabid(c)||' 記錄的NAME為'||v_tabname(c));
END LOOP;
dbms_output.put_line('---------------------------------');
--更新(返回更新后的值)
sql_str:='update emp set empno=1+empno,ename=''a'' where rownum=1 RETURNING empno,ename into :1,:2 ';
execute immediate sql_str RETURNING BULK COLLECT INTO v_tabid, v_tabname;
FOR c IN v_tabid.first..v_tabid.last LOOP
dbms_output.put_line('empno為'||v_tabid(c)||' 記錄的NAME為'||v_tabname(c));
END LOOP;
dbms_output.put_line('---------------------------------');
--刪除(返回被刪除的行)
sql_str:='delete from emp where rownum<=2 RETURNING empno,ename into :1,:2 ';
execute immediate sql_str RETURNING BULK COLLECT INTO v_tabid, v_tabname;
FOR c IN v_tabid.first..v_tabid.last LOOP
dbms_output.put_line('empno為'||v_tabid(c)||' 記錄的NAME為'||v_tabname(c));
END LOOP;
dbms_output.put_line('---------------------------------');
--插入(返回插入的行)
sql_str:='insert into emp(empno,ename) values(1,''abc'') RETURNING empno,ename into :1,:2 ';
execute immediate sql_str RETURNING BULK COLLECT INTO v_tabid, v_tabname;
FOR c IN v_tabid.first..v_tabid.last LOOP
dbms_output.put_line('empno為'||v_tabid(c)||' 記錄的NAME為'||v_tabname(c));
END LOOP;
dbms_output.put_line('---------------------------------');
/* 批fetch
語法:
fetch dynamic_cursor
bulk collect into define_variable[,define_variable...]
*/
sql_str:='select empno,ename from emp';
sql_str:=sql_str||' order by empno desc';
OPEN v_mycursor FOR sql_str;
--取
FETCH v_mycursor BULK COLLECT INTO v_tabid,v_tabname;
--關(guān)
CLOSE v_mycursor;
--輸
FOR c IN v_tabid.first..v_tabid.last LOOP
dbms_output.put_line('empno為'||v_tabid(c)||' 記錄的NAME為'||v_tabname(c));
END LOOP;
dbms_output.put_line('---------------------------------');
END;
2.-------
forall
DECLARE
/*批forall
語法:動態(tài)字符串必須為insert/update/delete,不能為select
forall index in lower..upper
execute immediate dynamic_string
using bind |bind(index)[,bind |bind(index)...]
[{returning|return} bulk collect into bind_argument[,bind_argument...]];
*/
TYPE sal_list IS TABLE OF number(8,2);
TYPE name_list IS TABLE OF varchar2(30);
TYPE dept_list IS VARRAY(15) OF integer;
v_depts dept_list:=dept_list(10,20,30,40,50,60,70,80);
v_tabsal sal_list:=sal_list();
v_tabname name_list:=name_list();
sql_str varchar2(200);
BEGIN
sql_str:='update emp set sal=sal*:arg1 where DEPTNO=:arg2';
sql_str:=sql_str||' returning ename,sal into :arg3,:arg4';
--給前面4個部門加薪10%,并返回結(jié)果到集合.
FORALL j IN 1..4
execute immediate sql_str
using 1.10,v_depts(j)
RETURNING BULK COLLECT INTO v_tabname,v_tabsal;
--顯示結(jié)果
FOR j IN v_tabname.first..v_tabname.last LOOP
dbms_output.put_line('雇員'||v_tabname(j)
||' 的薪水被提到'||v_tabsal(j));
END LOOP;
dbms_output.put_line('---------------------------------');
--給后面4個部門加薪20%,并返回結(jié)果到集合.
FORALL j IN 5..8
execute immediate sql_str
using 1.20,v_depts(j)
RETURNING BULK COLLECT INTO v_tabname,v_tabsal;
--顯示結(jié)果(用notfound判斷是否有結(jié)果集)
IF SQL%NOTFOUND THEN
dbms_output.put_line('無數(shù)據(jù)更新');
ELSE
FOR j IN v_tabname.first..v_tabname.last LOOP
dbms_output.put_line('雇員'||v_tabname(j)
||' 的薪水被提到'||v_tabsal(j));
END LOOP;
END IF;
END;
3.用一個值綁定綁定名稱相同的值.
把sql語句用begin end括起來就能實現(xiàn)
如:
execute immediate 'begin calc_stats(:x,:x,:y,:x,:y); end;' using a,b;
將A與X綁定,當(dāng)?shù)诙纬鰜聿煌Q時,與B綁定,以此類推
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 松溪县| 宜宾县| 商城县| 象州县| 镇坪县| 西畴县| 灵璧县| 灌阳县| 饶平县| 开鲁县| 松江区| 娄烦县| 芒康县| 邓州市| 衡水市| 沐川县| 宝坻区| 祁门县| 拉萨市| 凉城县| 郓城县| 康保县| 元朗区| 巨鹿县| 明溪县| 安阳县| 革吉县| 石首市| 望奎县| 福清市| 信阳市| 宝坻区| 湖南省| 盐津县| 屏南县| 搜索| 武陟县| 临邑县| 阿坝县| 洛南县| 游戏|