【Sql Server】存储过程的创建和使用事务,常见运用场景,以及目前现状

欢迎来到《小5讲堂》,大家好,我是全栈小5。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 前言
  • 创建存储过程
    • 创建格式
    • 返回数据集
    • 使用事务
    • 修改存储过程
    • 输出异常信息
    • 正确代码
  • 常见场景
  • 目前现状
  • 文章推荐

前言

上周有个小伙伴留言,让博主写一篇存储过程的知识点文章,
刚好趁此机会简单总结下存储过程,以及它的运用场景和现状。
存储过程可以写的很简答,也可以写的很复杂,看实际业务场景。

创建存储过程

创建格式

CREATE PROCEDURE procedure_name
    @parameter1 data_type1 = default_value1,
    @parameter2 data_type2 = default_value2,
    ...
AS
BEGIN
    -- 存储过程的逻辑代码
END

存储过程的主要结构包含以下几个部分:
1.存储过程名称(procedure_name)
用于标识存储过程的唯一名称。

2.输入参数(@parameter1, @parameter2, …)
可选的输入参数,用于接收外部传入的值。每个参数包括参数名、数据类型和默认值(可选)。

3.存储过程逻辑
在 BEGIN 和 END 之间编写存储过程的实际逻辑代码,可以包括各种 SQL 查询、更新、插入、删除等操作。

返回数据集

创建一个存储过程,用于返回一个查询数据集,基于之前文章创建过的表进行查询,具体可以在文章底部跳转链接查询。
这里的存储过程关键词procedure,可以缩写成proc。使用execute关键词执行创建好的存储过程以及传参

-- 创建存储过程
create proc my_query_proc
    @agent_name nvarchar(50)
as
begin
    select * from test_name where agent_name=@agent_name
end

-- 执行存储过程
declare @agent_name3 nvarchar(50)
set @agent_name3='''张三'''
execute my_query_proc @agent_name3

在这里插入图片描述

使用事务

通过传递值,在存储过程中执行操作,添加记录并且使用事务功能,事务关键词transaction,同样可以进行简写为tran。
下面存储过程代码,直接给自增id赋值是会报错,从而导致事务回滚。

-- 使用事务
create proc my_tran_proc
    @agent_name5 nvarchar(50)
as
begin
    begin transaction; -- 开始事务
    
    begin try
        insert into test_name(id,city_name,area_name,agent_name)
        values(1,'深圳市','龙岗区',@agent_name5)
    end try
    begin catch
        rollback transaction; -- 回滚事务
    end catch

    select * from test_name where agent_name=@agent_name5
end

-- 执行存储过程
declare @agent_name6 nvarchar(50)
set @agent_name6='''张三'''
execute my_tran_proc @agent_name6

在上面语句存在了报错情况,但是没有输出异常信息,如果添加成功,那么是会返回两条记录
在这里插入图片描述

修改存储过程

修改存储过程也很简答,通过可视化界面直接找到,在里面修改
在这里插入图片描述
在这里插入图片描述

输出异常信息

通过上一步修改存储过程后,再执行存储过程,切换到消息即可查看到输出的错误信息在这里插入图片描述

正确代码

-- 使用事务
alter proc my_tran_proc
    @agent_name5 nvarchar(50)
as
begin
    begin transaction; -- 开始事务
    
    begin try
        insert into test_name(city_name,area_name,agent_name)
        values('深圳市','龙岗区',@agent_name5)
    end try
    begin catch
        rollback transaction; -- 回滚事务
        declare @errorMessage nvarchar(4000) = error_message();
        print(@errorMessage)
    end catch

    select * from test_name where agent_name=@agent_name5
end

-- 执行存储过程
declare @agent_name6 nvarchar(50)
set @agent_name6='''张三'''
execute my_tran_proc @agent_name6

在这里插入图片描述

常见场景

SQL Server 存储过程的运用场景很多,

主要可分为以下几类:
1.执行复杂的数据处理操作
当需要进行复杂的数据处理时,可能需要多次查询、更新、插入、删除等操作。将这些操作封装在一个存储过程中可以简化代码的编写,提高效率,并且可以重复使用相同的代码逻辑。

2.提高数据库性能
存储过程可以被预编译,并且可以缓存执行计划,这样可以降低数据库服务器的负载并提高查询的执行效率。

3.简化应用程序代码
通过调用存储过程,应用程序可以将逻辑转移至数据库端,简化代码,提高效率,并且可以更容易地对数据库进行管理和维护。

4.加强数据安全性
存储过程可以设置权限控制,限制对数据库的访问权限,确保敏感数据的安全性,防止非法的操作。

5.实现事务操作
对于需要实现事务的数据库操作,可以使用存储过程来组织多个操作,确保事务的原子性。

总之,SQL Server 存储过程是一种强大而灵活的工具,可以用于解决各种不同的数据库需求,提高应用程序的效率和安全性。

目前现状

现在越来越多的公司在实际应用中减少了对存储过程的大量使用。博主在接触到的公司也确实是如此,也看实际业务情况。

这种趋势的主要原因包括:
1.ORM(对象关系映射)框架的普及和成熟
ORM框架(如Entity Framework、Hibernate等)的发展使得应用程序更倾向于采用对象关系映射的方式来处理数据操作,而不是直接使用存储过程。ORM框架可以将数据库表映射为对象,简化了数据访问层的开发和维护。

2.API 和微服务架构的兴起
随着微服务架构的流行,越来越多的公司将业务逻辑封装在独立的 API 中,而不是通过存储过程来实现。API 提供了更灵活的方式来访问和处理数据,同时也更易于扩展和维护。

3.更多的业务逻辑移到应用层
随着业务需求的不断变化,很多公司倾向于将更多的业务逻辑放在应用层实现,而不是存储过程中。这样可以更容易地控制和修改业务逻辑,也减少了对数据库的依赖。

尽管如此,存储过程仍然在某些特定场景下发挥着重要作用,比如处理复杂的数据逻辑、实现事务控制、提高数据库性能等。
因此,并不是所有的公司都完全弃用存储过程,而是根据具体的需求和情况决定是否使用存储过程。

文章推荐

【新星计划回顾】第六篇学习计划-通过自定义函数和存储过程模拟MD5数据

【新星计划回顾】第四篇学习计划-自定义函数、存储过程、随机值知识点

【Sql Server】Update中的From语句,以及常见更新操作方式

【Sql server】假设有三个字段a,b,c 以a和b分组,如何查询a和b唯一,但是c不同的记录

【Sql Server】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/430636.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

IPSEC---VPN

文章目录 目录 文章目录 一.TCP/IP 协议的缺点 二.IPsec诞生背景 IPsec可提供安全服务 三.IPsec协议簇 IPsec的两种工作模式 传输模式 隧道模式: IPsec的安全协议 AH 协议:鉴别头协议 ESP协议:封装安全载荷协议 AH与ESP对比 AHESP报文&#xff1a…

【笔记】【电子科大 离散数学】 3.谓词逻辑

谓词引入 因为含变量的语句(例如x > 3)不是命题,无法进行逻辑推理。 为了研究简单命题句子内部的逻辑关系,我们需要对简单命题进行分解,利用个体词,谓词和量词来描述它们,并研究个体与总体…

透明玻璃屏幕为什么那么贵

透明玻璃屏幕之所以价格较高,主要是由于以下几个方面的原因: 技术研发与创新:透明玻璃屏幕作为一种先进的显示技术,其研发和制造过程涉及到许多复杂的技术。这些技术的研发和创新需要投入大量的资金和时间。此外,透明玻…

推理判断01-程永乐-图形1

课程安排 出题形式 图形推理 1、位置规律 图形题目

供应商为啥要入驻政采网

供应商入驻政采网的原因主要有以下几点: 扩大企业知名度和商业机会:通过在政采网上的展示,可以让更多的政府机关、事业单位等了解企业的品牌和商品,提高企业的知名度,同时也会吸引更多的潜在客户,增加商业…

分布式数字身份:通往Web3.0世界的个人钥匙

数字化时代,个人身份已不再仅仅局限于传统形式,分布式数字身份(Decentralized Identity,简称DID)正崭露头角,它允许个人通过数字签名等加密技术,完全掌握和控制自己的身份信息。研究报告显示&am…

Chatgpt4.0国内使用网站公开。免费的都是假的。

Chatgpt简介 ChatGPT,这个名字自2022年底以来,在全球范围内引起了广泛的关注和讨论。它是由OpenAI公司开发的一款基于人工智能技术的语言模型,拥有惊人的自然语言处理和生成能力。ChatGPT不仅可以理解人类的语言,还能以类似人类的…

一本书讲透ChatGPT,实现从理论到实践的跨越!大模型技术工程师必读书籍【送书活动】

目录 前言一、内容简介二、作者简介三、专家推荐四、读者对象五、目录福利总结 前言 OpenAI 在 2022 年 11 月推出了人工智能聊天应用—ChatGPT。它具有广泛的应用场景,在多项专业和学术基准测试中表现出的智力水平,不仅接近甚至有时超越了人类的平均水平…

怎么将照片无损放大?三种简单方法分享

在数字影像领域,我们常常遇到需要放大图片却担心失真的困扰。如何在放大图片的同时保持清晰度和细节?让我们一起来探索三款强大的图片无损放大软件,助你轻松处理各种放大需求,释放画面细节,呈现令人惊喜的视觉效果&…

代码学习记录12

随想录日记part12 t i m e : time: time: 2024.03.05 主要内容:今天的主要内容是了解二叉树的理论基础,并且熟练掌握如何递归和迭代遍历二叉树。 理论基础递归遍历迭代遍历统一迭代 Topic1二叉树理论基础 1.二叉树的题…

ubuntu20.04设置docker容器开机自启动

ubuntu20.04设置docker容器开机自启动 1 docker自动启动2 容器设置自动启动3 容器自启动失败处理 1 docker自动启动 (1)查看已启动的服务 $ sudo systemctl list-units --typeservice此命令会列出所有当前加载的服务单元。默认情况下,此命令…

【QT】窗口的大小标题图标设置

窗口的大小标题图标设置 添加一个新的类 创建完成&#xff0c;根据上一节最后的在总结&#xff0c;做个测试&#xff1a; #include "mybutton.h" #include <QDebug>//打印&#xff0c;标准输出 MyButton::MyButton(QWidget *parent) : QPushButton(parent) { …

基于springboot的新闻推荐系统论文

基于springbootvue的新闻推荐系统 摘要 随着信息互联网购物的飞速发展&#xff0c;国内放开了自媒体的政策&#xff0c;一般企业都开始开发属于自己内容分发平台的网站。本文介绍了新闻推荐系统的开发全过程。通过分析企业对于新闻推荐系统的需求&#xff0c;创建了一个计算机…

09. Nginx进阶-Rewrite

简介 什么是rewrite&#xff1f; rewrite即URL重写&#xff0c;主要实现URL地址重写&#xff0c;以及重定向。 就是把插入web的请求重定向到其他URL的过程。 rewrite使用场景 URL地址调整 例如用户访问wang.mingqu.com将其跳转到ming.mingqu.com。 或者当用户通过http的方…

计算机丢失msvcp140_1.dll怎样修复,分享五种有效的解决方法

当计算机系统中msvcp140_1.dll文件发生丢失时&#xff0c;可能会引发一系列运行问题&#xff0c;具体表现形式多种多样。首先&#xff0c;由于msvcp140_1.dll是Microsoft Visual C Redistributable Package的重要组成部分&#xff0c;它的缺失将直接影响到依赖这一库的各类应用…

VLAN虚拟局域网络

VLAN的概念和配置: http://t.csdnimg.cn/g39F7http://t.csdnimg.cn/g39F7 VLAN中常见的接口类型 http://t.csdnimg.cn/mhahzhttp://t.csdnimg.cn/mhahz 实验&#xff1a;

KCMY1VUG12T8更大容量、更快企业级SSD NVMe PCIe

近年来&#xff0c;随着SSD固态硬盘技术的不断成熟和价格的进一步下降&#xff0c;SSD逐渐普及到市场。越来越多的企业、个人开始采用SSD&#xff0c;用户体验得到了显著提升。 最近感觉无论国内国外的客户需求均发生一些变化&#xff0c;具体主要体现在3个方面。 1、容量持续…

总结:直径测量的发展历程!在线测径仪已成主要方式!

测量在生活、生产和科学探究中扮演着至关重要的角色。从古至今&#xff0c;人们对测量的探索从未停止。而外径作为一种基础的几何尺寸&#xff0c;其测量也经过了多代发展&#xff0c;直到至今被广泛应用到工业生产中的在线测径仪。本文就来介绍一下外径测量的发展历程&#xf…

如何用Elementor创建WordPress会员网站

在下面的文章中&#xff0c;我们将向您展示如何使用Elementor和MemberPress在WordPress中轻松构建会员网站。这篇文章将涵盖WordPress会员网站设置过程、会员资格和受保护内容创建、重要页面和登录表单设计、电子邮件通知管理、报告等。 目录 什么是WordPress会员网站&#x…

5G智能制造热力工厂数字孪生可视化平台,推进热力行业数字化转型

5G智能制造热力工厂数字孪生可视化平台&#xff0c;推进热力行业数字化转型。在当今这个信息化、数字化的时代&#xff0c;热力生产行业也迎来了转型的关键时刻。为了提升生产效率、降低成本、提高产品质量&#xff0c;越来越多的热力生产企业开始探索数字化转型之路。而5G智能…