存储过程

引言:

    在机房重构中尝试了很多新鲜事物,以前只是听说或是理论上的一些知识,现在进行实践,跌跌撞撞中成长!

定义:

   在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。


优点:

A、 存储过程允许标准组件式编程
    存储过程创建后可以在程序中被多次调用执行,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可以随时对存储过程进行修改,但对应用程序源代码却毫无影响,从而极大的提高了程序的可移植性。
B、 存储过程能够实现较快的执行速度
    如果某一操作包含大量的T-SQL语句代码,分别被多次执行,那么存储过程要比批处理的执行速度快得多。因为存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,并给出最终被存在系统表中的存储计划。而批处理的T-SQL语句每次运行都需要预编译和优化,所以速度就要慢一些。
C、 存储过程减轻网络流量
    对于同一个针对数据库对象的操作,如果这一操作所涉及到的T-SQL语句被组织成一存储过程,那么当在客户机上调用该存储过程时,网络中传递的只是该调用语句,否则将会是多条SQL语句。从而减轻了网络流量,降低了网络负载。
D、 存储过程可被作为一种安全机制来充分利用
    系统管理员可以对执行的某一个存储过程进行权限限制,从而能够实现对某些数据访问的限制,避免非授权用户对数据的访问,保证数据的安全。


缺点:

A:调试麻烦,但是用 PL/SQL Developer 调试很方便!弥补这个缺点。
B:移植问题,据库端代码当然是与数据库相关的。但是如果是做工程型项目,基本不存在移植问题。
C:重新编译问题,因为后端代码是运行前编译的,如果带有引用关系的对象发生改变时,受影响的存储过程、包将需要重新编译(不过也可以设置成运行时刻自动编译)。
D:如果在一个程序系统中大量的使用存储过程,到程序交付使用的时候随着用户需求的增加会导致数据结构的变化,接着就是系统的相关问题了,最后如果用户想维护该系统可以说是很难很难、而且代价是空前的,维护起来更麻烦。 
注意:虽然存储过程有很多优点,但也存在缺点,因此,我们在用的时候进行权衡一下,不过现阶段我们就是为了用而用,先学会怎么用,再考虑要不要用!

怎么用

存储过程_第1张图片
打开SQL Sever,找到自己的数据库--可编译性--存储过程--右击新建存储过程,然后就出来一个模板(如下图)



存储过程_第2张图片
注释:
 SET ANSI_NULLS ON
 SQL-92 设置语句:SQL-92 标准要求在对空值进行等于 (=) 或不等于 (<>) 比较时取值为 FALSE。
当 SET ANSI_NULLS 为 ON 时,即使 column_name 中包含空值,使用 WHERE column_name = NULL 的 SELECT 语句仍返回零行。即使 column_name 中包含非空值,使用 WHERE column_name <> NULL 的 SELECT 语句仍会返回零行。
   当 SET ANSI_NULLS 为 OFF 时,等于 (=) 和不等于 (<>) 比较运算符不遵从 SQL-92 标准。使用 WHERE column_name = NULL 的 SELECT 语句返回 column_name 中包含空值的行。使用 WHERE column_name <> NULL 的 SELECT 语句返回列中包含非空值的行。此外,使用 WHERE column_name <> XYZ_value 的 SELECT 语句返回所有不为 XYZ_value 也不为 NULL 的行。


SET QUOTED_IDENTIRIER  ON
当 SET QUOTED_IDENTIFIER 为 ON 时,标识符可以由双引号分隔,而文字必须由单引号分隔。
当 SET QUOTED_IDENTIFIER 为 OFF 时,标识符不可加引号,且必须符合所有 Transact-SQL 标识符规则。
  
CREATE PROCEDURE <Procedure_Name, sysname, ProcedureName>
 创建存储过程的名称、数据库名
 下面就是添加一些参数,前面要加@,另外写明数据类型

SET NOCOUNT ON
当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数)
当 SET NOCOUNT 为 OFF 时,返回计数。 
-- Insert statements for procedure here
添加一些sql语句(增删改查)

这是我在机房注册中简单地应用了一下:

在D层中代码:
  Dim sqlhelper As New sqlHelper.sqlHelper
        'Dim cmdType As CommandType
        Dim sqlparams As SqlParameter() = {New SqlParameter("@studentNo", student.studentNo),
                                           New SqlParameter("@studentName", student.studentName),
                                           New SqlParameter("@sex", student.sex),
                                           New SqlParameter("@department", student.department),
                                           New SqlParameter("@grade", student.grade),
                                           New SqlParameter("@classes", student.classes),
                                           New SqlParameter("@cardNo", card.cardNo),
                                           New SqlParameter("@type", card.type),
                                           New SqlParameter("@cash", card.cash),
                                           New SqlParameter("@status", card.status),
                                           New SqlParameter("@date", card.dateR),
                                           New SqlParameter("@time", card.timeR),
                                           New SqlParameter("@userID", card.userID),
                                           New SqlParameter("@isCheck", card.isCheck)}
        Dim cmdText As String
        Dim result As Integer
        cmdText = "pro_Register"
        result = sqlhelper.AddDelUpdate(cmdText, CommandType.StoredProcedure, sqlparams)
        Return result


在每次接触新知识中不断成长!






你可能感兴趣的:(存储过程)