存储过程---留住你的美丽(上)

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

 
目录
相关文章
|
1天前
|
云安全 人工智能 自然语言处理
|
6天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
314 116
|
8天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
606 53
Meta SAM3开源:让图像分割,听懂你的话
|
21天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
5天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
|
4天前
|
弹性计算 人工智能 Cloud Native
阿里云无门槛和有门槛优惠券解析:学生券,满减券,补贴券等优惠券领取与使用介绍
为了回馈用户与助力更多用户节省上云成本,阿里云会经常推出各种优惠券相关的活动,包括无门槛优惠券和有门槛优惠券。本文将详细介绍阿里云无门槛优惠券的领取与使用方式,同时也会概述几种常见的有门槛优惠券,帮助用户更好地利用这些优惠,降低云服务的成本。
269 132
|
8天前
|
机器学习/深度学习 人工智能 自然语言处理
AgentEvolver:让智能体系统学会「自我进化」
AgentEvolver 是一个自进化智能体系统,通过自我任务生成、经验导航与反思归因三大机制,推动AI从“被动执行”迈向“主动学习”。它显著提升强化学习效率,在更少参数下实现更强性能,助力智能体持续自我迭代。开源地址:https://github.com/modelscope/AgentEvolver
419 29
|
15天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
727 223