‘壹’ 简述存储过程,触发器,函数的异同
触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行;你所说的函数是自定义函数吧,函数是根据输入产生输出,自定义只不过输入输出的关系 由用户来定义。在什么时候用触发器?要求系统根据某些操作自动完成相关任务,比如,根据买掉的产品的输入数量自动扣除该产品的库存量。什么时候用存储过 程?存储过程就是程序,它是经过语法检查和编译的sql语句,所以运行特别快。
‘贰’ 简单说说存储过程与触发器的概念与作用
存储过程就是一个sql的程序集 可以包含多个SQL语句 并可以附带各种逻辑判断及处理
触发器 就类似于程序里的事件触发
只是这里通常是某个字段的改变 某个表插入了数据 或者删除某些数据
以上这些处理引发的另外一些表数据的改变
‘叁’ 存储过程,函数和触发器的区别
存储过程,可以返回多个值,函数只能一个;触发器是一个特殊的存储过程。当他满足一当条件时执行,例子:如果几个有关联的表,其中主表的数据删除了~那么子表的也要一起删掉。这情况可以用触发,当主表数据删除时触发其它的操作。
‘肆’ 触发器的应用和用法
1、触发器的定义就是说某个条件成立的时候,触发器里面所定义的语句就会被自动的执行。因此触发器不需要人为的去调用,也不能调用。
2、触发器的触发条件其实在定义的时候就已经设定好了。
3、触发器可以分为语句级触发器和行级触发器。简单的说就是语句级的触发器可以在某些语句执行前或执行后被触发。而行级触发器则是在定义的了触发的表中的行数据改变时就会被触发一次。
4、具体举例:
1)、 在一个表中定义语句级的触发器,当这个表被删除时,程序就会自动执行触发器里面定义的操作过程。这个【删除表的操作】就是触发器执行的条件。
2)、 在一个表中定义行级的触发器,那当【这个表中一行数据发生变化】的时候,比如删除了一行记录,那触发器也会被自动执行了。
5、创建触发器语句
6、触发器作用(应用场景)
(1)数据确认
(2)实施复杂的安全性检查
(3)做日志记录,跟踪表上所做的数据操作等
(4)数据的备份和同步;
(4)阐述函数存储过程和触发器的用法扩展阅读
一、触发器介绍
1、数据库触发器是一个与表相关联的、存储的 PL/SQL 程序。每当一个特定的数据操作语句(Insert,update,delete)在指定的表上发出时,Oracle 自动地执行触发器中定义的语句序
列。
2、触发器的作用
触发器可用于:
(1)数据确认
(2)实施复杂的安全性检查
(3)做审计,跟踪表上所做的数据操作等
(4)数据的备份和同步
3、触发器的类型
(1)语句级触发器
在指定的操作语句操作之前或之后执行一次,不管这条语句影响了多少行 。
(2)行级触发器(FOR EACH ROW)
触发语句作用的每一条记录都被触发。在行级触发器中使用 old 和 new 伪记录变量,识别值的状态。
4、创建触发器的语法
CREATE [or REPLACE] TRIGGER 触发器名
{BEFORE |AFTER}
{DELETE | INSERT | UPDATE [OF 列名]}
ON 表名
[FOR EACH ROW [WHEN(条件) ] ]
参考资料
网络-Oracle触发器
‘伍’ 存储过程和触发器用在哪些方面举几个实例
存储过程就相当于子程序,比如批量处理SQL语句执行或执行SQL语言的编程。我用存储过程用的最多的地方就是数据库信息的分页查询。。
触发器的例子除了银行,最最常见的就是论坛啦。你回了别人一个帖子,数据库里就会增加这个帖子的内容,同时更新楼主的回帖数,同时还增加你的发帖数
‘陆’ 数据库存储过程、函数、触发器的区别
存储过程和函数的区别:
1. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
2. 对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
3. 存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
4. 当存储过程和函数被执行的时候,SQL Manager会到procere cache中去取相应的查询语句,如果在procere cache里没有相应的查询语句,SQL Manager就会对存储过程和函数进行编译。
Procere cache中保存的是执行计划 (execution plan) ,当编译好之后就执行procere cache中的execution plan,之后SQL SERVER会根据每个execution plan的实际情况来考虑是否要在cache中保存这个plan,评判的标准一个是这个execution plan可能被使用的频率;其次是生成这个plan的代价,也就是编译的耗时。保存在cache中的plan在下次执行时就不用再编译了。
触发器、存储过程和函数三者有何区别:
触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行;
在什么时候用触发器?要求系统根据某些操作自动完成相关任务。
什么时候用存储过程?
存储过程就是程序,它是经过语法检查和编译的SQL语句,所以运行特别快。
存储过程和用户自定义函数具体的区别
先看定义: 存储过程存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。
存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。 可以出于任何使用 SQL 语句的目的来使用存储过程,它具有以下优点: 可以在单个存储过程中。
‘柒’ 触发器和存储过程有什么区别,描述触发器的使用范围
触发器是一种特殊类型的存储过程,当使用下面的一种或多种数据修改操作在指定表中对数据进行修改时,触发器会生效:UPDATE、INSERT 或 DELETE.触发器可以查询其它表,而且可以包含复杂的 SQL 语句.它们主要用于强制复杂的业务规则或要求.例如,可以控制是否允许基于顾客的当前帐户状态插入定单.
触发器还有助于强制引用完整性,以便在添加、更新或删除表中的行时保留表之间已定义的关系.然而,强制引用完整性的最好方法是在相关表中定义主键和外键约束.如果使用数据库关系图,则可以在表之间创建关系以自动创建外键约束.有关详细信息,请参见表关系.
‘捌’ 数据库存储过程、函数、触发器的区别是什么
三者差别:
1、存储过程实现的功能要复杂一点,而函数实现的功能针对性比较强。;
2、存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用;
3、触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行。
分别含义:
1、存储过程的特点
①存储过程只在创建时进行编译,以后执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
② 当对数据库进行复杂操作时(如对多个表进行Update、Insert、Query、Delete时),可将此复杂操作用存储过程封装起来。
③可以在过程中调用另一个存储过程。可以在存储过程中调用函数。这可以简化一系列复杂语句。
④ 安全性高,可设定只有某用户才具有对指定存储过程的使用权。
⑤参数有三种(IN、OUT、IN OUT),可返回多个参数值。
⑥在ORACLE中,若干个有联系的过程可以组合在一起构成程序包。
⑦存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
2、函数的特点
①函数只有一种参数(IN),只有一条RETURN语句,只能返回单一的值。
②可在SQL语句(DML或SELECT)中调用函数。由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
3、触发器的特点
触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行。
‘玖’ SQL中触发器、存储过程
1、触发器:当向表unit插入的数据后,且objectid>10000时,向表test_tab插入数据
create
trigger
trig1
after
insert
on
unit
for
each
row
when
(objectid>10000)
begin
insert
into
test_tab
values(new.objectid,new.name);
end;存储过程:向表test插入调用存储时的参数@id,@namecreate
procere
pro_name
@id,@nameasbegininsert
into
test
values(@id,@name);end;2、两个区别,通过语法可以看出来,触发器是在执行了一定的操作后,根据触发条件,系统自动执行某一操作;而存储过程则是根据你设定的特定操作,来进行相应的操作而已。3、至于什么时候用触发器,什么时候用存储过程,这个就要根据你的使用情况了。比如说,在对某张表进行了特定操作后,我们让系统自动去执行一些操作,这个时候就可以使用触发器。而存储过程呢,如果我们在某一个事务中要进行的sql操作特别多,那么我们就可以把这些sql语句用存储过程来汇总,达到执行一遍存储过程就可以执行多条sql命令的目的。另外,你听说的现在不用触发器,这点明显是被误导了,触发器和存储过程是各有优点的。举个例子,比如说电信的通话记录,你可以想象每天的数据量有多大,那么为了保证系统的性能,我们就可以设定触发器来对表的容量进行限定,比如达到了1000万条数据,我们可以触发一个清表的操作,那么这张表就可以保证数据量始终在1000W以下(这个例子不是很合适,但是可以说明点问题)。之所以有人说不用触发器,这点也是从数据库性能来说的,说实话,使用触发器时,如果设计得不合适,那么对整个系统的性能会造成很大的影响的,所以在设计数据库时,一定要慎重。整个产品的性能并不是说代码优化就行了,数据库的架构设计也应该考虑在其中。
‘拾’ 存储过程和触发器的区别和联系。
我的理解:主要是使用场合不同,还有就是触发器中不能使用commit(这个应该是约定而不是规定)
存储过程相当于打包好的sql语法,可以包含复杂的sql操作,在程序调用时只要执行该存储过程,一句话就可以完成复杂的数据库操作.
触发器是也是打包好的sql语法,是一种特殊类型的存储过程,不由用户直接调用。创建触发器时会对其进行定义,以便在对特定表或列作特定类型的数据修改时执行
另外:触发器相对一般的存储过程也多了一些在代码编写方面的不同,比如说create
trigger
必须是批处理中的第一条语句,并且只能应用到一个表中等等.具体的可以看一下触发器的说明;http://ke..com/view/1189954.htm