- 浏览: 2276168 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (357)
- J2EE (49)
- JavaScript (40)
- Spring (19)
- Struts (5)
- CSS (8)
- Hibernate (16)
- Java (67)
- DWR (4)
- JSON (3)
- XFIRE (1)
- Tomcat (1)
- Ant (2)
- 设计模式 (2)
- 经典收藏 (2)
- JSP (10)
- Linux (0)
- WebLogic (11)
- myeclipse (13)
- Buffalo (4)
- 文件上传相关 (1)
- oracle (33)
- html (6)
- JSTL (3)
- SVN (2)
- GIT (1)
- 孙卫琴(Java网络编程精解) (1)
- DOM4J (2)
- Swing (1)
- AJAX (1)
- Eclipse (5)
- 日志组件 (3)
- PowerDesigner (1)
- Jquery (22)
- IT技术开发相关网址 (1)
- Nutz (1)
- 其它 (1)
- Velocity (3)
- WebService (1)
- MySql (2)
- Android (1)
- Maven (2)
- Quartz (11)
- Lucene (1)
- springsource (1)
- Junit (1)
- Activiti (0)
最新评论
-
yzlseu:
拼凑,没有营养
Activiti进阶—分配组任务 -
zhangsenhao:
非常赞!代码很清楚
SpringMVC3.0+MyIbatis3.0(分页示例) -
xiamw2000:
分页写得不对,应该是 : order by ${orderNa ...
SpringMVC3.0+MyIbatis3.0(分页示例) -
sheertewtw:
...
SpringMVC:上传与下载 -
kingtoon:
...
XSS之xssprotect
一 存储过程与函数的区别
1 存储过程
定义:
存储过程(Stored Procedure )是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
优 点:
A 存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
B 当对数据库进行复杂操作时(如对多个表进行Update、Insert、Query、Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句.
C 安全性高,可设定只有某用户才具有对指定存储过程的使用权。
D 存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值,可以向程序返回错误原因。
2 合理使用存储过程与函数
存储过程: 参数可以有三种模式(IN、OUT、IN OUT),可返回多个参数值.可在过程中调用另一个存储过程.
函数: 函数只有一种(IN),因为使用函数的目的是传入0或多个参数,它只有一条RETURN语句,只能返回单一的值,,也可用Out来返回值.可在SQL语句(DML或SELECT)中调用.
Oracle中的函数与存储过程的区别:
A:函数必须有返回值,而过程没有.
B:函数可以单独执行.而过程必须通过execute执行.
C:函数可以嵌入到SQL语句中执行.而过程不行.
其实我们可以将比较复杂的查询写成函数.然后到存储过程中去调用这些函数.
Oracle中的函数与存储过程的特点:
A. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
B.对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
C.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
3 存储过程与函数的相互使用
示例代码:
具体创建包及包体语法可参见链接:
http://liuzidong.iteye.com/admin/blogs/717050
A 创建包
B 创建包体
--存储过程的具体实现
for游标写法1:
for游标写法2:
for游标写法3:
动态SQL传递参数:userid为传递进来的参数.
1 存储过程
定义:
存储过程(Stored Procedure )是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
优 点:
A 存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
B 当对数据库进行复杂操作时(如对多个表进行Update、Insert、Query、Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。存储过程可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句.
C 安全性高,可设定只有某用户才具有对指定存储过程的使用权。
D 存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值,可以向程序返回错误原因。
2 合理使用存储过程与函数
存储过程: 参数可以有三种模式(IN、OUT、IN OUT),可返回多个参数值.可在过程中调用另一个存储过程.
函数: 函数只有一种(IN),因为使用函数的目的是传入0或多个参数,它只有一条RETURN语句,只能返回单一的值,,也可用Out来返回值.可在SQL语句(DML或SELECT)中调用.
Oracle中的函数与存储过程的区别:
A:函数必须有返回值,而过程没有.
B:函数可以单独执行.而过程必须通过execute执行.
C:函数可以嵌入到SQL语句中执行.而过程不行.
其实我们可以将比较复杂的查询写成函数.然后到存储过程中去调用这些函数.
Oracle中的函数与存储过程的特点:
A. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
B.对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
C.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
3 存储过程与函数的相互使用
示例代码:
具体创建包及包体语法可参见链接:
http://liuzidong.iteye.com/admin/blogs/717050
A 创建包
CREATE OR REPLACE PACKAGE davidliuzd AS --包头部分 --声明一个函数 --根据用户ID获取部门ID号 FUNCTION fun_getUserNDepartIdByUserID(UID in varchar2)return varchar2; -- 声明一个游标类型 TYPE DEPARTALL_CURSOR IS REF CURSOR; --声明一个存储过程 --根据用户ID获取所在部门的所有子部门信息集合 PROCEDURE proc_getDepartAllChildByUserID(UID in varchar2,dep_cur out DEPARTALL_CURSOR); END davidliuzd;--包体结束部分
B 创建包体
CREATE OR REPLACE PACKAGE BODY davidliuzd --包体部分 Is --函数的具体实现 FUNCTION fun_getUserNDepartIdByUserID (UID in varchar2)return varchar2 Is --返回值部门ID RDID TDEPAR.TID%TYPE; BEGIN --注意此处:传递进来的参数:userid与表的userid重复了,结果不对。 --你要修改传递参数的名称,--将参数修改下就行了. --select TID into RDID from TDEPART where userid=userid;--错误写法 select TID into RDID from TDEPART_USER where userID=UID; END IF; return RDID; END fun_getUserNDepartIdByUserID;
--存储过程的具体实现
PROCEDURE proc_getDepartAllChildByUserID (UID,in varchar2,dep_cur out DEPARTALL_CURSOR) AS RDID TDEPAR.TID%TYPE; BEGIN --注意此处是:存储过程中调用函数,体现了函数与存储过程的相互作用. Select fun_getUserNDepartIdByUserID(UID) into RDID from dual; --递归查询部门下所有子部门 open dep_cur for select * from TDEPART connect by DID=prior PARDID start with DID= RDID order by departmentID desc; END proc_getDepartAllChildByUserID; END davidliuzd;--包体结束 --在使用动态拼接 SQL中需要注意的地方: --示例: PROCEDURE proc_test(message out varchar2,uid in varchar2,uname in varchar2, nmr in varchar2) IS sqlstr varchar2(2000); BEGIN --正常写法 update 表名 set username=uname ,tag='1' where userid=uid and number like ‘%nmr%’; -- 另外一种写法: like nmr|| '%' --拼接sql语句写法,特别注意以下的’是多少个呀 --[ uname]二边用的是3个,[ 1]二边用的是2个. sqlstr : = 'update 表名 set username='''|| uname || ''',tag=''1'' where userid='''|| uid || ''' and number like ''%' || nmr || '%''; --IF,elsif,end if写法: if(tag = 1) then if a= 0 and b=0 then sqlstr := ‘select * from * else sqlstr := ' select * from * where …‘; end if; elsif(tag = 2) then end if;
for游标写法1:
FOR tt in (select * from …) LOOP if tt.id is not null and tt.tag = 1 then exit; end if; END LOOP;
for游标写法2:
open cur for select * from *; fetch cur into tt; while cur%found loop inituname :=tt.uname; initdid := tt.did; initdname := tt.dname; end loop; close cur;
for游标写法3:
type my is ref cursor; myhcur my; begin open myhcur for select * from …; fetch myhcur into p; loop fetch myhcur into obj; 进行取值操作… exit when myhcur%NOTFOUND; end loop; close res_cur;
动态SQL传递参数:userid为传递进来的参数.
Sqlstr :=’select * from 表名 where id=1’; open mycur for Sqlstr using userid;
- oracle存储过程_函数_动态SQL使用.rar (102.3 KB)
- 下载次数: 23
发表评论
-
oracle之INSTR函数
2011-10-13 15:33 18参考资料 1 Oracle的instr函数 http://kn ... -
oracle之DECODE()函数
2011-10-13 10:12 1419参考资料 1 oracle中的DECODE()函数 http: ... -
oracle之存储过程,临时表,游标示例
2011-09-22 11:58 7775参考资料 1 ORACLE 存储过程返回临时表结果集 htt ... -
oracle之删除临时表(14452)
2011-09-22 11:25 2837参考资料 1 Oracle临时表删除时的ORA-14452错误 ... -
oracle之truncate && delete
2011-09-22 09:19 2888参考资料 实例对比Oracle ... -
oracle之临时表
2011-09-20 14:49 1374参考资料 1 Oracle 临时表用法 http://www. ... -
oracle之随机数(结果集)
2011-09-20 11:32 2139参考资料 Oracle中随机抽 ... -
转载:本地每天定时备份数据库
2011-09-15 12:52 1272转载: 本地每天定时备份数据库 http://relic6.i ... -
Oracle之instr(字符串包含函数)
2011-07-29 11:01 49235参考资料 1 oracle函数大 ... -
oracle中关于in和exists,not in 和 not exists用法与区别
2011-06-27 10:25 4023参考资料 1 oracle中关于in和exists,not i ... -
Oracle:递归查询SQL
2011-05-06 16:59 2016有部门表: ID,PID --查询所有 select cou ... -
Oracle:行转列函数,查询重复记录函数,过滤表中重复记录函数
2011-04-28 11:34 27941 行转列函数: select wm_concat(usern ... -
Oracle:创建序列与触发器
2011-04-15 14:41 18011 创建序列(为触发器提供服务) create seque ... -
Navicat for Oracle Cannot load OCI DLL
2011-04-12 14:34 19140参考资料 Navicat for Oracle Cannot ... -
oracle: if...elseif...else用法
2011-03-31 16:38 15116参考资料 1 <转载>oracle存储过程中的if ... -
Oracle 自动生成 32位ID
2011-03-11 11:27 55341 code select SUBSTR(TO_CHAR ... -
Oracle split(分隔字符串函数)
2011-03-11 10:57 15342一 Oracle版本: 10g PLSQL: 8.0 二 具体 ... -
Oracle内连接、左外连接、右外连接、全外连接小总结
2011-01-24 11:11 13741转载:Oracle内连接、左外连接、右外连接、全外连接小总结 ... -
64位windows7 上安装32位oracle 10g 的方法
2010-12-23 12:17 3914转载:64位windows7 上安装32位oracle 10g ... -
Oracle 表解锁
2010-12-07 15:43 1557转载:Oracle 表解锁 http://toyota2006 ...
相关推荐
很清晰的说明了存储过程和函数的区别
MySQL实验报告5(存储过程与函数)(1)(1).pdf
MySQL 存储过程与函数 MySQL 存储过程和函数是数据库中定义的一组用户定义的 SQL 语句集合。它们之间的区别在于: 1. 存储过程实现的功能要复杂一点,而函数实现的功能针对性比较强。 2. 存储过程可以返回参数,而...
适合sqlserver数据库初学者,实验四存储过程和函数实验
常用SQL工具存储过程与函数.rar常用SQL工具存储过程与函数.rar
原创sql存储过程函数范例,一是为了自己方便查找,今天到公司因为没有我保存的一些范例,一个简单的例子写了半个小时,如果有范例直接套几分钟肯定搞定,所以索性上传到CSDN上,何时何地都能找到我的范例了。...
存储过程、函数、触发器和包
java调用oracle存储过程或者函数
Oracle实验报告
mysql存储过程,存储函数练习,里面有详细代码,供大家参考
主要介绍了Mysql存储过程和函数的区别,需要的朋友可以参考下
数据库存储过程和函数的使用方法 DB txt
Mysql存储过程和函数
实验八 存储过程和函数的使用 实验目的 (1)掌握存储过程的意义 (2)掌握存储过程的使用方法 (3)掌握函数的意义 (4)掌握函数的使用方法
讲解了oracle的编程存储过程、函数和包
Oracle存储过程和函数(最详细包含emp 表实例操作,边看边操作),目前最详细的存储过程文档,不好你举报我。含好多ORACLE SCOTT中emp表的实例。
Oracle存储过程、游标、函数的详解
视图、存储过程、函数、游标与触发器、
Oracle数据库存储过程、函数、以及包的创建与高级应用。