PL/SQL之DBMS_SQL程序包使用(1)(学习笔记)
dbms_sql程序包
dbms_sql程序包是系统提供给我们的另一种使用动态SQL的方法:
使用DBMS_SQL包实现动态的SQL的步骤如下:
1.将要执行的SQL语句或者一个语句放到一个字符串变量中
2.使用DBMS_SQL包的parse过程来分析该字符串
3.使用DBMS_SQL包的bind_varable过程绑定变量
4.使用DMBS_SQL包的execute函数和执行语句:
示例1:
--使用DBMS_SQL包执行DDL语句
--需求:使用DBMS_SQL包根据用户输入的表名,字段名及字段类型建表
DECLARE
TABLE_NAME VARCHAR2(20); --表名
FIELD1 VARCHAR2(20); --字段名
DATATYPE1 VARCHAR2(20); --字段类型
FIELD2 VARCHAR2(20); --字段名
DATATYPE2 VARCHAR2(20); --字段类型
V_CURSOR NUMBER; --定义光标
V_STRING VARCHAR2(200); --定义字符串变量
V_ROW NUMBER; --行数
BEGIN
TABLE_NAME := 't2';
FIELD1 := 'id';
DATATYPE1 := 'NUMBER';
FIELD2 := 'name';
DATATYPE2 := 'VARCHAR2(20)';
V_CURSOR := DBMS_SQL.OPEN_CURSOR; --为处理打开光标
V_STRING := 'create table ' || TABLE_NAME || '(' || FIELD1 || ' ' ||
DATATYPE1 || ',' || FIELD2 || ' ' || DATATYPE2 || ')';
DBMS_SQL.PARSE(V_CURSOR, V_STRING, DBMS_SQL.NATIVE); --分析语句
V_ROW := DBMS_SQL.EXECUTE(V_CURSOR); --执行语句
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭光标
DBMS_OUTPUT.PUT_LINE(V_ROW);
EXCEPTION
WHEN OTHERS THEN
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭光标
END;
SELECT * FROM t2;
示例2:
--使用DBMS_SQL包执行DML语句insert
DECLARE
ID NUMBER:=&ID;
NAME VARCHAR2(20):='&name';
v_cursor NUMBER; --定义光标
v_string VARCHAR2(200); --定义字符串变量
v_row NUMBER; --行数变量
BEGIN v_cursor:=dbms_sql.open_cursor; --打开光标
v_string:='insert into t2 values(:id,:name)';
dbms_sql.parse(v_cursor,v_string,dbms_sql.native); --分析语句
dbms_sql.bind_variable(v_cursor,'id',ID); --绑定变量
dbms_sql.bind_variable(v_cursor,'name',NAME); --绑定变量
v_row:=dbms_sql.execute(v_cursor); --执行动态SQL
COMMIT;
dbms_sql.close_cursor(v_cursor); --关闭光标
EXCEPTION
WHEN OTHERS THEN
dbms_sql.close_cursor(v_cursor); --关闭光标 END;
示例3:
-使用DBMS_SQL包执行DML语句
--需求:使用DBMS_SQL包将表中t2的id=1的名称改为Marry
DECLARE
ID NUMBER := &ID;
NAME VARCHAR2(20) := '&NAME';
V_CURSOR NUMBER; --定义光标
V_STRING VARCHAR2(200); --定义字符串变量
V_ROW NUMBER; --行数变量
BEGIN V_CURSOR := DBMS_SQL.OPEN_CURSOR; --打开光标
V_STRING := 'update t2 set name=:name where id=:id';
DBMS_SQL.PARSE(V_CURSOR, V_STRING, DBMS_SQL.NATIVE); --分析语句
DBMS_SQL.BIND_VARIABLE(V_CURSOR, 'name', NAME); --绑定变量
DBMS_SQL.BIND_VARIABLE(V_CURSOR, 'id', ID); --绑定变量
V_ROW := DBMS_SQL.EXECUTE(V_CURSOR); --执行动态SQL
COMMIT;
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭光标
EXCEPTION
WHEN OTHERS THEN
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭光标
RAISE;
END;
示例4:
--使用DBMS_SQL包执行DML语句delete
DECLARE
ID NUMBER := &ID; --定义id
V_CURSOR NUMBER; --定义光标
V_ROW NUMBER; --定义行数
V_STRING VARCHAR2(200); --定义字符串变量
BEGIN V_CURSOR:=DBMS_SQL.OPEN_CURSOR; --打开光标
V_STRING := 'delete from t2 where id=:id';
DBMS_SQL.PARSE(V_CURSOR, V_STRING, DBMS_SQL.NATIVE); --分析语句
DBMS_SQL.BIND_VARIABLE(V_CURSOR, 'id', ID); --绑定字段ID
V_ROW := DBMS_SQL.EXECUTE(V_CURSOR); --执行动态SQL
COMMIT;
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭光标
EXCEPTION
WHEN OTHERS THEN
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭光标
RAISE;
END;
查询
--示例五:
使用DBMS_SQL包执行DML语句select DECLARE
V_ID emp.deptno%TYPE:= &ID; --定义变量
V_STRING VARCHAR2(200); --定义字符串变量
V_EMPNO NUMBER;
V_NAME VARCHAR2(20);
V_CURSOR NUMBER; --定义光标
V_ROW NUMBER; --定义行
BEGIN v_cursor:=dbms_sql.open_cursor; --打开光标
V_STRING := 'select empno,ename from emp where deptno=:deptno';
DBMS_SQL.PARSE(V_CURSOR, V_STRING, DBMS_SQL.NATIVE); --分析语句
DBMS_SQL.BIND_VARIABLE(V_CURSOR, 'deptno', V_ID); --绑定字段 DBMS_SQL.DEFINE_COLUMN(V_CURSOR,1,V_EMPNO);
DBMS_SQL.DEFINE_COLUMN(V_CURSOR,2,V_NAME,20); --如果是有长度需要指定找长度 V_ROW := DBMS_SQL.EXECUTE(V_CURSOR); --执行 LOOP
EXIT WHEN DBMS_SQL.FETCH_ROWS(V_CURSOR) <= 0; --解析游标,
DBMS_SQL.COLUMN_VALUE(V_CURSOR,1,V_EMPNO); --将当前行的数据写入上面对应的列中。
DBMS_SQL.COLUMN_VALUE(V_CURSOR,2,V_NAME);
DBMS_OUTPUT.PUT_LINE('no:' || V_EMPNO || ' enmae:' || V_NAME); --输出内容
END LOOP;
DBMS_SQL.CLOSE_CURSOR(V_CURSOR); --关闭游标
END;
PL/SQL之DBMS_SQL程序包使用(1)(学习笔记)的更多相关文章
- Java程序猿的JavaScript学习笔记(汇总文件夹)
最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...
- Java程序猿的JavaScript学习笔记(8——jQuery选择器)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(3——this/call/apply)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(1——理念)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(10—— jQuery-在“类”层面扩展)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(12——jQuery-扩展选择器)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(9—— jQuery工具方法)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(6——面向对象模拟)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
- Java程序猿的JavaScript学习笔记(5——prototype和Object内置方法)
计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...
随机推荐
- codecombat js
#1 // Move to the gem. // Don't touch the walls! // Type your code below. this.moveRight(); this.mov ...
- C#访问修饰符总结[转]
http://blog.csdn.net/tjvictor/article/details/4293354 C#共有五种访问修饰符:public.private.protected.internal. ...
- 力特ZE398C驱动光盘-USB转RS232-支持Windows 10/Mac
这个工具是USB1.1的,相对来说比较老,一开始做小白鼠不知道买了USB1.1的,所以我不建议买这个,还有其它的型号,支持USB2.0和USB3.0,不过价格也相对来说比较贵,这个才30块钱左右. 关 ...
- [Linux] VIM Practical Note
Practical Vim 文件 1.1. 管理多个文件 1.1.1. 缓冲区 • :ls • 查看缓冲区列表 • :bprev • 前一项 • :bnext • 后一项 • :bfirst • 第一 ...
- JTAG/SPI/ISP/ICSP 接口电路
- JVM内存模型及垃圾回收算法
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- android 利用 aapt 解析 apk 得到应用名称 包名 版本号 权限等信息
在上传各大市场时发现 apk 上传后能自动解析出应用名称.包名.版本号.使用权限等信息,所以就研究了一下 1 直接解压 apk 解析 AndroidManifest.xml 是不行的,因为 apk ...
- E470 外放没声音问题解决
到官网下载声卡驱动.和热键驱动,安装就ok了
- C++常用排序法、随机数
C++常用排序法研究 2008-12-25 14:38 首先介绍一个计算时间差的函数,它在<time.h>头文件中定义,于是我们只需这样定义2个变量,再相减就可以计算时间差了. 函数开头加 ...
- 【BZOJ】【3170】【TJOI2103】松鼠聚会
切比雪夫距离+曼哈顿距离 题解:http://www.cnblogs.com/zyfzyf/p/4105456.html 其实应该先做这题再做[BZOJ][3210]花神的浇花集会的吧…… 我们发现d ...