plsql开发笔记和小结

上传人:正** 文档编号:41197311 上传时间:2018-05-28 格式:DOC 页数:52 大小:31.07KB
返回 下载 相关 举报
plsql开发笔记和小结_第1页
第1页 / 共52页
plsql开发笔记和小结_第2页
第2页 / 共52页
plsql开发笔记和小结_第3页
第3页 / 共52页
plsql开发笔记和小结_第4页
第4页 / 共52页
plsql开发笔记和小结_第5页
第5页 / 共52页
点击查看更多>>
资源描述

《plsql开发笔记和小结》由会员分享,可在线阅读,更多相关《plsql开发笔记和小结(52页珍藏版)》请在金锄头文库上搜索。

1、* PLSQL 基本结构 * 基本数据类型变量基本数据类型变量基本数据类型变量基本数据类型变量 1. 基本数据类型 Number 数字型 Int 整数型 Pls_integer 整数型,产生溢出时出现错误 Binary_integer 整数型,表示带符号的整数 Char 定长字符型,最大 255 个字符 Varchar2 变长字符型,最大 2000 个字符 Long 变长字符型,最长 2GB Date 日期型 Boolean 布尔型(TRUE、FALSE、NULL 三者取一) 在 PL/SQL 中使用的数据类型和 Oracle 数据库中使用的数据类型,有的含义是完全一致 的,有的是有不同的含义

2、的。 2. 基本数据类型变量的定义方法 变量名 类型标识符 not null:=值; declare age number(3):=26; -长度为 3,初始值为 26 begin commit; end; 其中,定义常量的语法格式: 常量名 constant 类型标识符 not null:=值; declare pi constant number(9):=3.1415926;-为 pi 的数字型常量,长度为 9,初始值为3.1415926 begin commit; end; 表达式表达式表达式表达式 变量、常量经常需要组成各种表达式来进行运算,下面介绍在 PL/SQL 中常见表达式的 运

3、算规则。 1. 数值表达式 PL/SQL 程序中的数值表达式是由数值型常数、变量、函数和算术运算符组成的,可以 使用的算术运算符包括+(加法) 、-(减法) 、*(乘法) 、/(除法 )和*(乘方)等。 命令窗口中执行下列 PL/SQL 程序,该程序定义了名为 result 的整数型变量,计算的是10+3*4-20+5*2 的值,理论结果应该是 27。 set serveroutput on Declare result integer; begin result:=10+3*4-20+5*2; dbms_output.put_line(运算结果是:|to_char(result); end;

4、 dbms_output.put_line 函数输出只能是字符串,因此利用 to_char 函数将数值型结果 转换为字符型。 2. 字符表达式 字符表达式由字符型常数、变量、函数和字符运算符组成,唯一可以使用的字符运算符 就是连接运算符“|” 。 3. 关系表达式 关系表达式由字符表达式或数值表达式与关系运算符组成,可以使用的关系运算符包括 以下 9种。 大于 = 等于(不是赋值运算符:=) like 类似于 in 在之中 = 大于等于 != 不等于 或4)精度上限值 -报错不能存储 number(3,-3):=44445 1、根据刻度3 进行四舍五入得到 44000 2、小数点向前移动 3

5、位 44.此位置为刻度精确到的位置 3、根据精度进行判断 2 位(,通过 outername 变量名来访问 外部过程的变量(待测试.) 。 declare v_i1 binary_integer:=1; begin declare v_i2 binary_integer:=2; begin dbms_output.put_line(v_i1); dbms_output.put_line(v_i2); end; dbms_output.put_line(v_i1); -dbms_output.put_line(v_i2); 解开后执行 Oracle 会提示“必须说明标识符 V_I2” end;

6、* PLSQL 流程控制 * if 判断判断判断判断 declare v_b boolean:=true; begin if v_b then dbms_output.put_line(ok); end if; end; if else 判断判断判断判断 declare v_b boolean:=true; begin if v_b then dbms_output.put_line(ok); else dbms_output.put_line(false); end if; end; if elsif else 判断判断判断判断 declare v_name varchar2(20):=ch

7、eng; begin if v_name=0701 then dbms_output.put_line(0701); elsif v_name=cheng then dbms_output.put_line(cheng); else dbms_output.put_line(false); end if; end; loop 循环循环循环循环,注意推出 exit 是推出循环,而不是推出整个代码块 declare v_i binary_integer:=0; begin loop if v_i10 then exit; end if; v_i:=v_i+1; dbms_output.put_li

8、ne(hehe); end loop; dbms_output.put_line(over); end; loop 简化写法简化写法简化写法简化写法 declare v_i binary_integer :=0; begin loop exit when v_i10; v_i :=v_i+1; dbms_output.put_line(hehe); end loop; dbms_output.put_line(over); end; while 循环循环循环循环 declare v_i binary_integer:=0; begin while v_iv_id; begin v_id:=10

9、; open c_student; close c_student; end; 第三种游标的定义方式,带参数的游标,用的最多。 declare cursor c_student(v_id binary_integer) is select * from book where idv_id; begin open c_student(10); close c_student; end; 游标的使用游标的使用游标的使用游标的使用, ,一定别忘了关游标一定别忘了关游标一定别忘了关游标一定别忘了关游标。 。 declare v_student book%rowtype; cursor c_studen

10、t(v_id binary_integer) is select * from book where idv_id; begin open c_student(10); fetch c_student into v_student; close c_student; dbms_output.put_line(v_student.name); end; 如何遍历游标如何遍历游标如何遍历游标如何遍历游标 fetch 游标的属性 %found,%notfound,%isopen,%rowcount。 %found:若前面的 fetch 语句返回一行数据,则%found 返回 true,如果对未打开的

11、游标使 用则报 ORA-1001 异常。 %notfound,与%found 行为相反。 %isopen,判断游标是否打开。 %rowcount:当前游标的指针位移量,到目前位置游标所 检索的数据行的个数,若未打开就引用,返回 ORA-1001。 注注注注: no_data_found 和%notfound 的用法是有区别的,小结如下 1)SELECT . . . INTO 语句触发 no_data_found; 2)当一个显式光标(静态和动态)的 where 子句未找到时触发 %notfound; 3)当 UPDATE 或 DELETE 语句的 where 子句未找到时触发 sql%notf

12、ound; 4)在光标的提取(Fetch)循环中要用 %notfound 或%found 来确定循环的退出条件,不要用no_data_found。 下面是几个实例: create table BOOK ( ID VARCHAR2(10) not null, BOOKNAME VARCHAR2(10) not null, PRICE VARCHAR2(10) not null, CID VARCHAR2(10) not null ); -insert create or replace procedure say_hello( i_name in varchar2, o_result_msg o

13、ut varchar2 ) as v_price varchar2(100); e_myException exception; begin insert into book(id,bookname,price) values (1,2,3); o_result_msg := success; exception when others then rollback; o_result_msg := substr(sqlerrm, 1, 200); end; -update or delete create or replace procedure say_hello( i_name in va

14、rchar2, o_result_msg out varchar2 ) as v_price varchar2(100); e_myException exception; begin update book set price = 55 where bookname = i_name; delete from book where bookname = i_name; if sql%notfound then raise e_myException; end if; /* if sql%rowcount = 0 then-写法 2 raise e_myException; end if; *

15、/ o_result_msg := success; exception when e_myException then rollback; o_result_msg := update or delete dail; end; -select create or replace procedure say_hello( i_name in varchar2, o_result_msg out varchar2 ) as v_price varchar2(100); e_myException exception; begin select price into v_price from book where bookname = i_name; o_result_msg := success; exception

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号