.NET重构(五):存储过程、触发器和函数的区别
2015-01-25 15:15
288 查看
导读:在触发器的学习过程中,师傅讲了它的耦合性高,建议我能用存储过程,那到底什么是存储过程呢,自己也不是特别了解,还有就是,触发器也算是一种特殊的存储过程,为什么就不建议多用呢?接下来,就谈谈触发器、存储过程以及函数的区别!
一、存储过程
1,定义
存储过程(Stored Procedure):是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
PS:根据我自己的使用情况,我感觉存储过程其实就是一些写好的SQL语句集,就像是函数方法一样,都写好了封起来,需要用的时候,直接调用。
2,特点
1)、变量说明
2)、ANSI(美国国家标准化组织)兼容的SQL命令(如Select,Update….)
3)、一般流程控制命令(if…else…、while….)
4)、内部函数
3,实例说明
4,优点
首先,存储过程可以复用。比如说上面的存储过程,我认为,只要是组合查询的,都可以使用。
其次,方便省事。因为这个存储过程是事先编辑好的,以后需要使用的时候,直接调用。而不需要再重新去写SQL语句。
最后,存储过程还可以防止SQL注入。(个人认为是和参数化查询有关!)
二、对比学习
1,存储过程对比函数
返回变量:函数返回一个,存储过程可以有多个。
使用范围:函数可以嵌入SQL中,存储过程不行。
针对性:函数强,存储过程较弱。
另外,存储过程一般作为一个独立的整体执行,而函数可以嵌入到SQL中作为一个部分执行。(比如在这之中用到的返回表名的那个方法,就是嵌入到SQL语句中使用)
2,存储过程和触发器
首先:触发器是一种特殊的存储过程。
自动化:存储过程需要在使用的时候调用,而触发器在满足条件的时候自动触发。
三、总结
总结起来,目前对于存储过程、触发器和函数这三者的区别,就可以用下面的一张表来反应。
![](https://img-blog.csdn.net/20150125191716892?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaGh4MDYyNg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
四、个人感受
其实,好像不管做什么,都是在为了解耦和。然后解耦和的目的是什么呢,是为了适应需求的变化,也就是满足用户!也真的是:用户的需求就是上帝!
然后,把东西放到它该到的地方去,就是最好的。
一、存储过程
1,定义
存储过程(Stored Procedure):是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
PS:根据我自己的使用情况,我感觉存储过程其实就是一些写好的SQL语句集,就像是函数方法一样,都写好了封起来,需要用的时候,直接调用。
2,特点
1)、变量说明
2)、ANSI(美国国家标准化组织)兼容的SQL命令(如Select,Update….)
3)、一般流程控制命令(if…else…、while….)
4)、内部函数
3,实例说明
<span style="font-size:18px;"><span style="font-family:KaiTi_GB2312;font-size:24px;">ALTER PROCEDURE [dbo].[QueryGroup] -- Add the parameters for the stored procedure here @cmbField1 varchar(10), @cmbOperation1 varchar(10), @txtContent1 varchar(10), @cmbField2 varchar(10), @cmbOperation2 varchar(10), @txtContent2 varchar(10), @cmbField3 varchar(10), @cmbOperation3 varchar(10), @txtContent3 varchar(10), @cmbRelation1 varchar(10), @cmbRelation2 varchar(10), @tableName varchar(20) AS declare @TempSql varchar(500)--临时存放sql语句 BEGIN SET @TempSql='SELECT * FROM '+@tableName +' WHERE ' +@cmbField1 +@cmbOperation1+char(39) + @txtContent1 + char(39) if @cmbRelation1 != ''--如果第一个组合关系不为空 BEGIN --在第一个查询条件的基础上,加上第二个查询条件 SET @TempSql=@TempSql+@cmbRelation1+CHAR(32)+@cmbField2 +@cmbOperation2+CHAR(39)+@txtContent2+CHAR(39) if @cmbRelation2!= ''--如果第二个组合关系也不为空 BEGIN --加上第三个查询条件 SET @TempSql=@TempSql+@cmbRelation2+CHAR(32)+@cmbField3+@cmbOperation3+CHAR(39)+@txtContent3+CHAR(39) END END EXECUTE(@TempSql) END</span></span>
4,优点
首先,存储过程可以复用。比如说上面的存储过程,我认为,只要是组合查询的,都可以使用。
其次,方便省事。因为这个存储过程是事先编辑好的,以后需要使用的时候,直接调用。而不需要再重新去写SQL语句。
最后,存储过程还可以防止SQL注入。(个人认为是和参数化查询有关!)
二、对比学习
1,存储过程对比函数
返回变量:函数返回一个,存储过程可以有多个。
使用范围:函数可以嵌入SQL中,存储过程不行。
针对性:函数强,存储过程较弱。
另外,存储过程一般作为一个独立的整体执行,而函数可以嵌入到SQL中作为一个部分执行。(比如在这之中用到的返回表名的那个方法,就是嵌入到SQL语句中使用)
2,存储过程和触发器
首先:触发器是一种特殊的存储过程。
自动化:存储过程需要在使用的时候调用,而触发器在满足条件的时候自动触发。
三、总结
总结起来,目前对于存储过程、触发器和函数这三者的区别,就可以用下面的一张表来反应。
四、个人感受
其实,好像不管做什么,都是在为了解耦和。然后解耦和的目的是什么呢,是为了适应需求的变化,也就是满足用户!也真的是:用户的需求就是上帝!
然后,把东西放到它该到的地方去,就是最好的。
相关文章推荐
- .NET重构(五):存储过程、触发器和函数的区别
- 数据库中存储过程、函数、触发器的区别
- 触发器,存储过程,函数区别
- 存储过程,函数,触发器的区别
- 存储过程、函数、触发器的区别
- 数据库存储过程、函数、触发器的区别
- 存储过程 函数 触发器的区别
- 解决:System.Data.SqlClient.SqlException: 超出了存储过程、函数、触发器或视图的最大嵌套层数(最大层数为 32).
- 破解加密存储过程,函数,视图,触发器
- 触发器、存储过程和函数三者有何区别?(转)
- 存储过程与函数的区别
- 解决:System.Data.SqlClient.SqlException: 超出了存储过程、函数、触发器或视图的最大嵌套层数(最大层数为 32).
- Oracle: 删除当前用户的所有对象(表、视图、触发器、存储过程、函数)
- 触发器、存储过程和函数三者有何区别?(转)
- Oracle和SQL Server的一些区别(函数和存储过程)
- SQL中存储过程和自定义函数的区别
- Oracle和SQL Server的一些区别(函数和存储过程)
- 触发器、存储过程和函数三者有何区别?
- 查看SQLSERVER加密存储过程,函数,触发器,视图
- 解密SQLSERVER2000存储过程,函数,视图,触发器