存储过程与视图

存储过程与视图存储过程与视图

大家好,又见面了,我是你们的朋友全栈君。

    还记得自考时数据库系统原理中的存储过程、视图吗?那时候我们已经掌握了创建存储过程和视图的基本语句,这在机房重构的过程中扮演了不可缺少的角色。

存储过程

一.存储过程的好处

    存储过程是在大型数据库系统中,一组为了完成特定功能的SQL语句集。——百度百科

    小编理解的存储过程:有时我们的一个功能需要对多张表执行操作,比如下机时,首先要把下机信息更新到下机表中,还需要更新卡表中的余额,如果一张表一张表的更新,就需要写两条SQL语句,执行两次调用过程,然而代码大部分都是相同的,所以存储过程就派上了用场,把要执行的多条SQL语句同时写到一个存储过程中,执行一次调用过程就OK啦。

    存储过程的使用,首先使我们的程序代码更简洁,其次还体现了“高内聚低耦合“的思想。

二.在SQL Server中创建存储过程

1.找到自己创建的数据库—–>可编程性—–>存储过程

2.右击存储过程点“新建存储过程”

3.新建存储过程的SQL语句

USE [myCharge]
GO
/****** Object:  StoredProcedure [dbo].[proc_Offline]    Script Date: 2015/12/27 20:31:54 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:		<Author,,Name>
-- Create date: <Create Date,,>
-- Description:	<Description,,>
-- =============================================
ALTER PROCEDURE [dbo].[proc_Offline]
	@cardNo char(10),
	@offDate datetime,
	@consumeTime int,
	@consume decimal,
	@cash decimal,
	@status char(10)
AS
BEGIN
	update onlineLog set offDate =@offDate ,consumeTime =@consumeTime ,consume =@consume ,cash =@cash ,status =@status where cardNo=@cardNo 
	update card set cash =@cash where cardNo =@cardNo 
END

4.在D层中调用存储过程

    '更新下机信息
    Public Function updateOffline(Offline As offLineModel) As Boolean Implements IOnlineInfo.updateOffline
        '命令的文本内容现在把SQL语句改为存储过程的名称proc_Offline
        cmdText = "proc_Offline"
        '给存储过程中的参数传值
        paras = {New SqlParameter("offDate", Offline.OffTime),
                 New SqlParameter("consumeTime", Offline.ConsumeTime),
                 New SqlParameter("consume", Offline.Consume),
                 New SqlParameter("cardNo", Offline.CardNo),
                 New SqlParameter("cash", Offline.CardNo),
                 New SqlParameter("status", Offline.State)
            }
        '调用SQL Helper
        helper.ExecuteNoQuery(cmdText, CommandType.StoredProcedure, paras)
        flag = True
        Return flag
    End Function

关于SQL Helper如何写,参见上一篇《SQL Helper》

视图

一.视图的好处

    以上下机为例,由于上机是需要显示卡的类型、余额、学生的学号、姓名等信息,而卡的信息需要从card表中查询,学生的信息需要从student表中查询,所以如果在代码中只使用简单的SQL语句,需要多次查询,有时不小心还会出现一些错误,所以把自己需要查询的内容放在一个视图中,查询起来就更加高效方便。

二.在SQL Server中创建视图

1.找到自己创建的数据库—–>视图

2.右击存储过程点“新建视图”

3.选择添加“card”表和“student”表。

存储过程与视图

4.在各个表中选择自己需要查询的字段

存储过程与视图

5.保存视图,刷新视图就可以看到自己新建的视图了。

存储过程与视图

存储过程与视图

    以上是通过向导来创建视图的过程,并自动生成SQL语句。我们也可以自己通过SQL语句创建视图,不过从上面的SQL语句看来,SQL语句创建视图,很容易就会丢掉或写错其中的一个字段,当我们对SQL语句十分熟练时,可以考虑,平时用上面的方法就挺方便的。

6.在视图中查询内容的SQL语句

    '查询学生和卡的相关信息
    Public Function StuandCard(Card As cardInfo) As DataTable Implements IOnlineInfo.StuandCard
        '下面的SQL语句中,把表明替换为视图名即可
        cmdText = "select * from View_InquireStuCardInfo where cardNo = '" & Card.CardNo & "'"
        table = helper.ExecSelectNo(cmdText, CommandType.Text)
        Return table
    End Function

存储过程VS视图

相同点:都可以同时对多张表操作。

不同点:存储过程适用于多张表同时执行增(insert)删(delete)改(update)的SQL语句

        视图适用于多张表同时执行查询(Select)的SQL语句

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105760.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 网络推广100种方法有哪些_100种宣传方式

    网络推广100种方法有哪些_100种宣传方式一米软件发现网上很多人都在找网络推广100种方法,但 其实网站推广并不是方法越多越好,而是找到适合自己的方法为宜,下面一米软件就来给大家介绍下一些常用网站推广的方法。1、搜索引擎营销搜索引擎营销,这种方法一般是通过自建官网然后针对官网进行优化与更新,使得网站在搜索引擎中有一个好的排名。也有通过做付费推广,使得网站的某个关键词在搜索引擎中有个好的排名。2、自媒…

    2022年4月20日
    190
  • Java中this关键字详解

    Java中this关键字详解一、this关键字主要有三个应用: (1)this调用本类中的属性,也就是类中的成员变量; (2)this调用本类中的其他方法; (3)this调用本类中的其他构造方法,调用时要放在构造方法的首行。PublicClassStudent{Stringname;//定义一个成员变量nameprivatevoidSetName(Stringname){

    2022年6月17日
    31
  • 用tushare获取股票历史数据

    用tushare获取股票历史数据我们运用python进行量化分析的时候需要载入证券数据,tushare为我们提供了证券市场数据接口。tushare是以新浪财经、腾讯财经、上交所数据、深交所数据为基础提供的Python接口。安装方法为pipinstalltushare也可以到tushare的官网去下载,并且官网上有接口各个调用函数的详细说明http://tushare.org/index.html#id5

    2022年6月24日
    26
  • dosbox基础使用[通俗易懂]

    dosbox运行程序1、mountc:d:\masm64把d盘masm64的内容挂在到c盘中2、c:进入c盘3、masmname.asm编译name的asm文件,后面要敲回车masmname.asm;编译name的asm文件,后面不用敲回车4、linkname连接name的文件,后面要敲回车linkname;连接name的文件,后面不用敲回车5、name运行name的文件dubug程序1、挂载、进入c盘步骤和前面一样2、debugname.exe3、输入命令

    2022年4月15日
    141
  • ubuntu进tty1_linux最小系统板

    ubuntu进tty1_linux最小系统板这个系统很迷你。完全符合变态操作控的习惯,如果你很喜欢洁净的系统,那么它就是你的玩具~可以试试自己的能力,是否能够在这系统里DIY一个属于你自己的LINUX。。。转载于:https://www.cnblogs.com/xiaoCon/archive/2013/03/31/2991221.html…

    2025年5月22日
    1
  • 如何用python显示一个弹窗_appium golang

    如何用python显示一个弹窗_appium golang以微信登录界面的toast弹窗为例:我的appium版本是1.17.1,服务器运行时日志有这样的打印信息所以我的desired_caps如下(如果是之前的版本,需要安装uiautomator2,并且在初始化时指定automationName为uiautomator2):desired_caps_a={‘platformName’:”Android”,’platFormVersion’:”10″,’d.

    2022年9月24日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号