存储过程,是什么呢?分解来看,存储--根据不同的应用环境通过采取合理、安全、有效的方式将数据保存到某些介质上并能保证有效的访问,总的来讲可以包含两个方面的含义:一方面它是数据临时或长期驻留的物理媒介;另一方面,它是保证数据完整安全存放的方式或行为。过程--事物发展所经过的程序;阶段。“过程”,也是将输入转化为输出的系统。
在我们的计算机的世界里,百度对存储过程这样进行阐述:存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
在我们的计算机的世界里,百度对存储过程这样进行阐述:存储过程(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语句的时候,直接写存储过程的名字即可,这样做的好处可以重复使用,从而可以减少数据库开发工作人员的工作量;提高了性能;减少了网络流量;提高了安全性。在机房收费系统中,涉及三个组合查询,如何让三个组合查询使用用一个存储过程,尽情期待,下篇博文存储过程---留住你的美丽(下),第二版机房收费系统,未完,待续......