PL编程.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
1,块(编程): 存储过程 触发器 函数 包 2,命名规范: 定义变量:建议 v_ 作为前缀 如:v_name ; 定义常量:建议c_作为前缀 如:c_num; 定义游标:建议 _cursor最为后缀 如:emp_cursor; 定义例外:建议e_最为前缀 如:e_notData; ,3,块编程: ·定义部分 ·执行部分 ·异常处理部分 declare --定义常量,变量,游标,复杂数据类型。。 begin -- 执行部分 exception -- 异常处理部分 end; set serveroutput on ; -- 打开输出选项 才可以输出:dbms_output.put_line(.....); 4,复杂数据类型 |- %type --对于一个字段的类型 --%type的数据类型 declare --定义类型和emp表中的ename字段的类型一样, ---这样就可以不需要知道ename的类型才来定义变量了 v_ename emp.ename%type; begin select ename into v_ename from emp where empno = 7788; dbms_output.put_line(v_ename); end; --%rowtype的复杂数据类型 declare --%rowtype是针对一张表的所有的字段 v_empInfo emp%rowtype; begin select * into v_empInfo from emp where empno=7788; dbms_output.put_line(名字:|| v_empInfo.ename|| , 工作: || v_empInfo.job); end;--多个字段,并非一张表的全部字段 declare --先要定义这种类型的数据包括哪几个字段信息 type v_emp_rcType is record(v_ename emp.ename%type , v_job emp.job%type); --还要将这个类型赋值给一个变量 v_emp_info v_emp_rcType; begin select ename,job into v_emp_info from emp where empno=7788; --要得到这种类型里面的某一个字段,就可以 刚才被赋予这种类型的变量.定义时候的参数 dbms_output.put_line(名字:|| v_emp_info.v_ename|| , 工作: || v_emp_info.v_job); end;declare type v_emp_cursor is ref cursor; -- 定义一个游标 v_emps v_emp_cursor; -- 给游标赋值给变量 v_ename emp.ename%type; begin --打开游标 open v_emps for select ename from emp; loop fetch v_emps into v_ename; -- 取出右边的数据 exit when v_emps%notfound ; -- 退出循环的条件,当游标已经是最后一行了 dbms_output.put_line(v_ename); end loop; close v_emps;--关闭游标 注意:在PL编程中, = 是比较的意思 , 要给变量赋值 := 如: 赋值常量 c_num number:=5 ; 运算的时候赋值 v_n := v_n +1 ; 5,语法: 条件语句 |- if--then --- end if; |- if-- then --else -- end if; create or replace procedure sp_pcd_2(empname varchar2) is v_comm m%type; begin select comm into v_comm from emp where ename = empname; if nvl(v_comm,0)!=0 then-- 也可以是 update emp set comm = nvl(v_comm,0) + 100 where ename = empname; else update emp set comm = nvl(v_c

您可能关注的文档

文档评论(0)

***** + 关注
实名认证
文档贡献者

本账号下所有文档分享可拿50%收益 欢迎分享

1亿VIP精品文档

相关文档