- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
plsq笔记l
替换已存在的过程名
创建存储过程
create (or replace) procedure my_pl is
begin
/////
执行部分
/////
end;
/
带参
SQL create procedure sp_test2(spname varchar2,newclassid number)is
2 begin
3 update student set classid=newclassid where studentname=spname;
4 end;
5 /
show error—查看错误
调用过程
exec 过程名(参数值1,……)
call过程名(参数值1,……)
命名规范:
变量:v_变量名;
常量:c_常量名;
游标:名字_cursor;
例外:e_名字;
///////
块结构
set serveroutput on(默认为off)
declared
-定义部分(可选)
begin
-执行部分(必须)
exception
-例外处理
end;
-结束
/
例:
begin
dbms_output.put_line(hello);
end;
/
输出结果:hello
当.put_line换成.put是不能输出!?
变量命名规则
字母、数字、特殊符号 字母开头,不区分大小写;
最大30个字符
不能有空格
例:
set serveroutput on;
declare
v_student varchar2(20);
begin
select studentname into v_student from student where xh=xh;
dbms_output.put_line(姓名:||v_student);
exception
when no_data_found then
dbms_output.put_line(查无此人);异常处理
end;
/ 2012/2/21
1、函数的创建;
create function sp_fun1(spname varchar2)return
number is spage number(3);
begin
select age+1 into spage from student where studentname=spname;
return spage;
end;
2、调用函数
var 变量名 类型;
exec 函数名(‘参数’) into:变量名;
创建包
- 创建包名
create package sp_pa is
-声明过程
procedure update_age(name varchar2,newage number);
-声明函数
function fun_age(name varchar2) return number;
end;
创建包体
2012/2/22
使用标量
declare
c_tax_rate number(3,2):=0.03;
v_ename varchar2(5);
v_sal number(7,2);
v_tax_sal number(7,2);
begin
select ename ,sal into v_ename,v_sal from emp where empno=no;
v_tax_sal:=v_sal*c_tax_rate;
dbms_output.put_line(姓名:||v_ename||工资:||v_sal||税款:||v_tax_sal);
end;
表名.列名%type 会引用原表属性解决缓冲区小的问题,防止溢出
定义记录类型
记录多个变量
declare
type emp_record_type is record(name emp.ename%type,salary emp.sal%type,title emp.job%type);
sp_record emp_record_type;
begin
select ename,sal,job into sp_record from emp where empno=7788;
dbms_output.put_line(员工:||sp_record.name||工资||sp_record.salary);
end;
游标
declare
--定义游标类型为 sp_emp_cursor
type sp_emp_cursor is ref cursor;
test_cursor(游标变量) sp_emp_cursor;
v_ename emp.ename%type;
您可能关注的文档
最近下载
- 标准的测试用例模板(仅用于学习的参考模板).doc VIP
- 高中地理课件湘教版:3-4海陆分布对气压带风带的影响及季风环流.pptx
- DB31-30-2003 住宅装饰装修验收标准.pdf VIP
- 西安地铁电缆事件工程伦理案例分析.ppt VIP
- 电路分析简明教程第三版傅恩锡习题答案.docx VIP
- 含高清图经络穴位歌诀及白话解.doc VIP
- 2020年高考物理备考微专题精准突破专题1.11 动力学中的传送带问题(解析版).pdf VIP
- MS600-35标准-涂层及涂层覆膜的测试方法中文版.pdf VIP
- 口腔健康调查问卷实践总结5篇.docx VIP
- 博物馆展览内容设计规范.pdf VIP
文档评论(0)