Oracle 数据库执行批处理脚本

Oracle 数据库执行批处理脚本

1、执行批量赋值脚本

/*** DML ***/
declare
v_sql varchar2(500) := '';
v_condition VARCHAR2(200) := ' ';
v_relationyear number :=0;
v_relationmonth number :=0;
v_relationweek number :=0;
v_relationdays number :=0;
v_relationhours number :=0;
v_relationminute number :=0;
v_relationseconds number :=0;
v_relationworkorder number :=0;
v_relationwarehose number :=0;
v_relationworkgroup number :=0;
begin
v_sql := 'select
t.relationyear,
t.relationmonth,
t.relationweek,
t.relationdays,
t.relationhours,
t.relationminute,
t.relationseconds,
t.relationworkorder,
t.relationwarehose,
t.relationworkgroup
from materialbatch t where 1=1' || v_condition;
execute immediate v_sql
into
v_relationyear,
v_relationmonth,
v_relationweek,
v_relationdays,
v_relationhours,
v_relationminute,
v_relationseconds,
v_relationworkorder,
v_relationwarehose,
v_relationworkgroup;
DBMS_OUTPUT.put_line('v_relationyear--' || v_relationyear ||',---v_relationworkgroup---'||v_relationworkgroup);
commit;
end;

2、执行删除表和创建表脚本

/*** DDL ***/ 
begin 
EXECUTE IMMEDIATE 'drop table table_001'; 
EXECUTE IMMEDIATE 'create table table_001(name varchar2(8),address varchar2(200))'; 
end;

3、执行插入脚本

/*** DML ***/ 
declare 
v_1 varchar2(8); 
v_2 varchar2(10); 
str varchar2(50); 
begin 
v_1:='张三'; 
v_2:='中国'; 
str := 'INSERT INTO table_001(name ,address) VALUES (:1, :2)'; 
EXECUTE IMMEDIATE str USING v_1, v_2; 
commit; 
end;

4、返回结果集过程

CREATE OR REPLACE package pkg_test as 
/* 定义ref cursor类型 
不加return类型,为弱类型,允许动态sql查询, 
否则为强类型,无法使用动态sql查询; 
*/ 
type myrctype is ref cursor; 

--函数申明 
function get(intID number) return myrctype; 
end pkg_test; 
/ 

CREATE OR REPLACE package body pkg_test as 
--函数体 
function get(intID number) return myrctype is 
rc myrctype; --定义ref cursor变量 
sqlstr varchar2(500); 
begin 
if intID=0 then 
--静态测试,直接用select语句直接返回结果 
open rc for select id,name,sex,address,postcode,birthday from 
student; 
else 
--动态sql赋值,用:w_id来申明该变量从外部获得 
sqlstr := 'select id,name,sex,address,postcode,birthday from student 
where id=:w_id'; 
--动态测试,用sqlstr字符串返回结果,用using关键词传递参数 
open rc for sqlstr using intid; 
end if; 

return rc; 
end get; 

end pkg_test; 
/

5、返回单行结果

declare  
    str varchar2(500);  
    c_1 varchar2(10);  
    r_1 test%rowtype;  
begin  
    c_1:='张三';  
    str:='select * from test where name=:c WHERE ROWNUM=1';  
    execute immediate str into r_1 using c_1;  
    DBMS_OUTPUT.PUT_LINE(R_1.NAME||R_1.ADDRESS);  
end ;

本文作者:Journey&Flower

本文链接:https://www.cnblogs.com/JourneyOfFlower/p/14214746.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   Journey&Flower  阅读(537)  评论(0编辑  收藏  举报
评论
收藏
关注
推荐
深色
回顶
收起
点击右上角即可分享
微信分享提示
  1. 1 404 Not Found REOL
  2. 2 白色恋人 游鸿明
  3. 3 盛夏的果实 莫文蔚
  4. 4 以父之名 周杰伦
  5. 5 晴天 周杰伦
  6. 6 简单爱 周杰伦
  7. 7 东风破 周杰伦
  8. 8 稻香 周杰伦
  9. 9 爱在西元前 周杰伦
  10. 10 千里之外 费玉清-周杰伦
  11. 11 偏爱 张芸京
  12. 12 大海 张雨生
  13. 13 月亮惹的祸 张宇
  14. 14 雨一直下 张宇
  15. 15 过火 张信哲
  16. 16 隐形的翅膀 张韶涵
  17. 17 天下 张杰
  18. 18 当你孤单你会想起谁 张栋梁
  19. 19 清明雨上 许嵩
  20. 20 玫瑰花的葬礼 许嵩
  21. 21 断桥残雪 许嵩
  22. 22 城府 许嵩
  23. 23 等一分钟 徐誉滕
  24. 24 客官不可以 徐良_小凌
  25. 25 坏女孩 徐良_小凌
  26. 26 犯贱 徐良
  27. 27 菠萝菠萝蜜 谢娜
  28. 28 贝多芬的悲伤 萧风
  29. 29 睫毛弯弯 王心凌
  30. 30 我不是黄蓉 王蓉
  31. 31 秋天不回来 王强
  32. 32 今天你要嫁给我 陶喆,蔡依林
  33. 33 丁香花 唐磊
  34. 34 绿光 孙燕姿
  35. 35 求佛 誓言
  36. 36 十一年 邱永传
  37. 37 下辈子如果我还记得你 马郁
  38. 38 一千年以后 林俊杰
  39. 39 江南 林俊杰
  40. 40 曹操 林俊杰
  41. 41 背对背拥抱 林俊杰
  42. 42 会呼吸的痛 梁静茹
  43. 43 勇气 梁静茹
  44. 44 爱你不是两三天 梁静茹
  45. 45 红日 李克勤
  46. 46 星月神话 金莎
  47. 47 嘻唰唰 花儿乐队
  48. 48 穷开心 花儿乐队
  49. 49 六月的雨-《仙剑奇侠传》电视剧插曲 胡歌
  50. 50 一个人的寂寞两个人的错 贺一航
  51. 51 好想好想-《情深深雨濛濛》电视剧片尾曲 古巨基
  52. 52 情人 刀郎
  53. 53 冲动的惩罚 刀郎
  54. 54 西海情歌 刀郎
  55. 55 2002年的第一场雪 刀郎
  56. 56 红玫瑰 陈奕迅
  57. 57 浮夸 陈奕迅
  58. 58 爱情转移 陈奕迅
  59. 59 独家记忆 陈小春
  60. 60 记事本 陈慧琳
  61. 61 看我72变 蔡依林
  62. 62 寂寞在唱歌 阿桑
  63. 63 樱花草 Sweety
  64. 64 中国话 S.H.E
  65. 65 波斯猫 S.H.E
  66. 66 杀破狼-《仙剑奇侠传》电视剧片头曲 JS
  67. 67 Lydia F.I.R.
  68. 68 I Miss You 罗百吉_青春美少女.
白色恋人 - 游鸿明
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

作词 : 林利南

作曲 : 游鸿明

编曲 : 涂惠源

冷空气 却清晰

你在南极冰山雪地里

极光中雪白的肌肤

是哀愁是美丽

为了要遇见你

我连呼吸都反复练习

兰伯特仁慈的冰川

带领我走向你

零下九十一度的酷寒

滚滚红尘千年的呼喊

藏在沃斯托克的湖岸

沉寂轻叹

撒哈拉漫天狂沙 金字塔谁能解答

兵马俑谁与争锋 长城万里相逢

人世间悲欢聚散 一页页写在心上

含着泪白色恋人 却有灰色的年轮

零下九十一度的酷寒

滚滚红尘千年的呼喊

藏在沃斯托克的湖岸

沉静轻叹

撒哈拉漫天狂沙 金字塔谁能解答

兵马俑谁与争锋 长城万里相逢

人世间悲欢聚散 一页页写在心上

含着泪白色恋人 却有灰色的年轮

撒哈拉漫天狂沙 金字塔谁能解答

兵马俑谁与争锋 长城万里相逢

人世间悲欢聚散 一页页写在心上

含着泪白色恋人 却有灰色的年轮