存储过程---留住你的漂亮(上)

        存储过程,是什么呢?分解来看,存储--依据不同的应用环境通过採取合理、安全、有效的方式将数据保存到某些介质上并能保证有效的訪问,总的来讲能够包括两个方面的含义:一方面它是数据暂时或长期驻留的物理媒介;还有一方面,它是保证数据完整安全存放的方式或行为。过程--事物发展所经过的程序。阶段。

“过程”,也是将输入转化为输出的系统。
        在我们的计算机的世界里。百度对存储过程这样进行阐述:存储过程(Stored Procedure)是在大型数据库系统中。一组为了完毕特定功能的SQL 语句集。经编译后存储在数据库中,用户通过指定存储过程的名字并给出參数(假设该存储过程带有參数)来运行它。

存储过程是数据库中的一个重要对象。不论什么一个设计良好的数据库应用程序都应该用到存储过程。

       以下结合机房收费系统中的组合查询--学生基本信息维护为例,该功能的逻辑,依据不同的条件选择。查询对应信息。接下来:看看我们的存储过程怎样在她的世界动情演绎,首先我们来看一下存储过程的创建。

       首先:第一步

        

       第二步:

       

      接下来就開始编译我们的存储过程了代码例如以下:

      

<span style="font-size:18px;">-- =============================================
-- Author:		<丁国华>
-- Create date: <2014年7月30日 12:14:52,>
-- Description:	<组合查询--学生基本信息维护>
-- =============================================
CREATE PROCEDURE [dbo].[Proc_StuInfoPreserve]
	-- Add the parameters for the stored procedure here
	@cboFieldA varchar(10),           --字段名A
	@cboOperatorA varchar(10),        --操作符A
	@txtContentA varchar(10),         --要查询的内容A
	@cboRelationA varchar(10),        --组合关系A
	@cboFieldB varchar(10),           --字段名B
	@cboOperatorB varchar(10),        --操作符B
	@txtContentB varchar(10),         --要查询的内容B
	@cboRelationB varchar(10),        --组合关系B
	@cboFieldC varchar(10),           --字段C
	@cboOperatorC varchar(10),        --操作符C
	@txtContentC varchar(10)          --表名或视图名称
	
AS
   declare @strText varchar(500)--暂时存放sql语句
   --CHAR(32)是空格,CHAR(39)单引號
BEGIN
	-- SET NOCOUNT ON added to prevent extra result sets from
	-- interfering with SELECT statements.
	set @strText ='select * from T_Student where '+CHAR(32)
	+@cboFieldA+@cboOperatorA+CHAR(39)+@txtContentA +CHAR(39)+
    CHAR(32)+@cboRelationA +CHAR (32)+
    @cboFieldB+@cboOperatorB +CHAR(39)+@txtContentB+CHAR(39)+
    CHAR(32)+@cboRelationB+CHAR(32)+
    @cboFieldC+@cboOperatorC+CHAR(39)+@txtContentC+CHAR(39)
    execute(@strText)
END
GO</span>
         上述存储过程的写法,报出例如以下错误:

         

        错误的原因就是存储过程写错了,存储过程应该究竟应该怎么写呢?正确做法例如以下:

         

<span style="font-size:18px;">USE [MachineRoomChargeSystem]
GO
/****** Object:  StoredProcedure [dbo].[Proc_StuInfoPreserve]    Script Date: 07/31/2014 16:49:33 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:		<丁国华>
-- Create date: <2014年7月30日 12:14:52,>
-- Description:	<组合查询--学生基本信息维护>
-- =============================================
ALTER PROCEDURE [dbo].[Proc_StuInfoPreserve]
	-- Add the parameters for the stored procedure here
	@cboFieldA varchar(10),           --字段名A
	@cboOperatorA varchar(10),        --操作符A
	@txtContentA varchar(10),         --要查询的内容A
	@cboRelationA varchar(10),        --组合关系A
	@cboFieldB varchar(10),           --字段名B
	@cboOperatorB varchar(10),        --操作符B
	@txtContentB varchar(10),         --要查询的内容B
	@cboRelationB varchar(10),        --组合关系B
	@cboFieldC varchar(11),           --字段C
	@cboOperatorC varchar(10),        --操作符C
	@txtContentC varchar(10)          --要查询的内容C
	
	
AS
   declare @strText varchar(500)--暂时存放sql语句
   --CHAR(32)是空格,CHAR(39)单引號
BEGIN
	-- SET NOCOUNT ON added to prevent extra result sets from
	-- interfering with SELECT statements.
	set @strText ='select * from T_Student where'+CHAR(32)
	+@cboFieldA+@cboOperatorA+CHAR(39)+@txtContentA +CHAR(39)
	if @cboRelationA!=''
	begin
	set @strText=@strText+@cboRelationA+CHAR(32)+
    @cboFieldB+@cboOperatorB+CHAR(39
    )+@txtContentB+CHAR(39)
    end
	if @cboRelationB!=''
	begin
	set @strText=@strText+@cboRelationB+CHAR(32)+
    @cboFieldC+@cboOperatorC+CHAR(39)+@txtContentC+CHAR(39)
    end
    execute(@strText)
    
	
END
 </span>
        那么我们的D层有该怎么去写呢?曾经写sql语句的地方。应该怎样进行对应变动,写法例如以下:

        

<span style="font-size:18px;">'**********************************************
'文 件 名: T_StudentDAL
'命名空间: DAL
'内    容: 对学生表的一系列增删改查的操作
'功    能: 
'文件关系:
'作    者:丁国华
'小    组:宝贝计划
'生成日期: 2014/7/17 10:15:17
'版本:V2.0
'改动日志:
'版权说明:
'**********************************************

  ''' <summary>
    ''' 学生基本信息维护,依据条件的相关选择,查询出对应信息
    ''' </summary>
    ''' <param name="cboFieldA"></param>
    ''' <param name="cboOperatorA"></param>
    ''' <param name="txtContentA"></param>
    ''' <param name="cboRelationA"></param>
    ''' <param name="cboFieldB"></param>
    ''' <param name="cboOperatorB"></param>
    ''' <param name="txtcontentB"></param>
    ''' <param name="cboRelationB"></param>
    ''' <param name="cboFieldC"></param>
    ''' <param name="cboOperatorC"></param>
    ''' <param name="txtContentC"></param>
    ''' <returns></returns>
    ''' <remarks></remarks>
    Public Function QueryStuInfoPre(cboFieldA As String, cboOperatorA As String, txtContentA As String, cboRelationA As String, cboFieldB As String, cboOperatorB As String, txtcontentB As String, cboRelationB As String, cboFieldC As String, cboOperatorC As String, txtContentC As String) As List(Of Entity.StudentEntity) Implements IStudent.QueryStuInfoPre
        Dim strText As String = "Proc_StuInfoPreserve" '这里的strText不在存放单条SQL语句,而是存储过程
        Dim cmdType As CommandType = CommandType.StoredProcedure '命令类型
        Dim parameter As SqlParameter() '传參数

        parameter = {New SqlParameter("@cboFieldA", cboFieldA),
                    New SqlParameter("@cboOperatorA", cboOperatorA),
                    New SqlParameter("@txtContentA", txtContentA),
                    New SqlParameter("@cboRelationA", cboRelationA),
                    New SqlParameter("@cboFieldB", cboFieldB),
                    New SqlParameter("@cboOperatorB", cboOperatorB),
                    New SqlParameter("@txtContentB", txtcontentB),
                    New SqlParameter("@cboRelationB", cboRelationB),
                    New SqlParameter("@cboFieldC", cboFieldC),
                    New SqlParameter("@cboOperatorC", cboOperatorC),
                    New SqlParameter("@txtContentC", txtContentC)}

        Dim sqlHelper As New SqlHelper
        Dim dt As New DataTable
        Dim myList As List(Of Entity.StudentEntity)

        dt = sqlHelper.ExecuteReaderTable(strText, cmdType, parameter)
        myList = EntityHelper.convertToList(Of Entity.StudentEntity)(dt)
        Return myList

    End Function
</span>
          结合机房收费系统,我对存储过程的理解就是。把一推sql语句写到存储过程中,在系统中涉及到sql语句的时候,直接写存储过程的名字就可以。这样做的优点能够反复使用,从而能够降低数据库开发工作人员的工作量;提高了性能。降低了网络流量。提高了安全性。在机房收费系统中。涉及三个组合查询,怎样让三个组合查询使用用一个存储过程,尽情期待,下篇博文存储过程---留住你的漂亮(下),第二版机房收费系统。未完,待续......

 
原文地址:https://www.cnblogs.com/claireyuancy/p/6759273.html