存储过程的学习

1,前言        

        这是实习期间学习的,我可能是在学校没好好听课,(或者就是学校比较垃,没教这部分,在公司经理让我下去自己学习,太难了,因为是公司代码很多部分都是很多表的操作,所以导致都是存储过程,我最开始一脸懵)

        存储过程适用于各种关系型数据库,它就相当于是多条sql语句写在一起,写成了一个程序,可以一起执行。(可能不准确,但是我觉得比较便于理解)

        百度百科解释:存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,它存储在数据库中,一次编译后永久有效,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象。在数据量特别庞大的情况下利用存储过程能达到倍速的效率提升。

        根据此解释,我们可以分析一下,抓住其中几个关键部分:

2,存储过程的优点
(1)重复使用,存储过程可以重复使用,从而可以减少数据库开发人员的工作量。
(2)一次编译后永久有效,能够实现较快的执行速度
(3)能够减少网络流量
(4)可被作为一种安全机制来充分利用,可以防止sql注入攻击

3,适用情况

        由此可见,存储过程优点还是很多的,虽然也有缺点,但是使用与否还是要看实际情况,存储过程适用于:

        复杂业务逻辑:涉及多个表、多次查询和更新操作的复杂业务流程

        批量操作:导入大量数据、批量更新或删除数据。

        提高性能。

        数据安全性和权限控制。

        数据一致性和事务管理:存储过程可以包含事务处理语句,确保一系列数据库操作的原子性和一致性。

        对于简单的数据库操作或只涉及单个查询的情况,直接在应用程序中执行SQL语句可能更为简洁和高效。(所以,会了存储过程可不能写一个简单的单表查询就用存储过程)

4,存储过程的分类

        存储过程可分为三类:系统提供的存储过程、用户自定义存储过程和扩展存储过程
        系统:系统提供的存储过程,sp_*
        扩展:SQL Server环境之外的动态链接库DLL,xp_
        远程:远程服务器上的存储过程
        用户:创建在用户数据库中的存储过程
        临时:属于用户存储过程,#开头(局部:一个用户会话),##(全局:所有用户会话)

5,创建用户存储过程

        首先,肯定是先找到位置,打开存储过程,下面是两个软件不同位置,一个是可编程性,一个是函数。

         下面就是最最最重要的了, 如何开始写存储过程

        例如我们创建一个存储过程(空):

CREATE PROCEDURE [dbo].[abc]
AS
BEGINEND格式
CREATE PROC 过程名
@形参名 类型
@变参名 类型 OUTPUT
AS SQL语句

        其中[abc]是存储过程的名字,可以就行更改,只要再次进行编译就可以。

        简单的写两个实例:

        1,创建一个多表查询的存储过程

USE ABC
GO
CREATE PROCEDURE [dbo].[abc]
AS
SELECT x.sid,x.sname,y.cid,y.grade
FROM student x INNER JOIN sc y
ON x.sid=y.sid
WHERE x.sid=‘101010’

        2,利用输出参数计算阶乘

USE ABC
IF EXISTS(SELECT name FROM sysobjects
WHERE name=‘bcd’ AND type=‘P’) --名称是bcd类型是procedure
DROP PROCEDURE factorial
GO
CREATE PROCEDURE [dbo].[bcd]
@in float , --输入形式参数
@out float OUTPUT --输出形式参数
AS
DECLARE @i int
DECLARE @s float
SET @i=1
SET @s=1
WHILE @i<=@in
BEGIN
SET @s=@s*@i
SET @i=@i+1
END
SET @out=@s --给输出参数赋值

由此可见,存储过程也不难理解,它还有另外几部分:

调用存储过程
DECLARE @ou float
EXEC factorial 5,@ou out --实参表
PRINT @ou

删除存储过程
语法:
Drop procedure 过程名
SSMS方式删除:右键点击该存储过程,删除

修改存储过程
语法:
Alter procedure 过程名
As
SQL 语句

        以上是对存储过程简单的介绍,具体还有在程序中使用的部分,如何调用,需要什么参数,这都是需要继续的学习

        最后给大家看一下我学习成果,我写的一段简单的存储过程:

USE [XXX]
GOSET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:
-- Last Date:   
-- Description:  数据校验
-- =============================================
ALTER PROCEDURE [dbo].[XXX_OfflineDataCheck2]
@EngineSerialNo NVARCHAR(255) = NULL,
@EngineType NVARCHAR(255) = NULL
AS
BEGIN
SET NOCOUNT ON;
DECLARE @QCOUNT INT, @TCOUNT INT, @Result INT, @TYPE NVARCHAR(255)
SET @Result = 0
SELECT @TYPE = LocationNo FROM Mst_Product WHERE @EngineType = @EngineType
IF @TYPE = '33'
BEGINSELECT @TCOUNT = COUNT(*) FROM Trn_InspectionConfig WHERE EngineType = @EngineType AND StationCode NOT IN ('F01-3','F03-3','M15-2','S04-2','S13-2','S14-2','S15-2','F06','F07','F08')
END
ELSE
BEGINSELECT @TCOUNT = COUNT(*) FROM Trn_InspectionConfig WHERE EngineType = @EngineType AND StationCode NOT IN ('F01-3','F03-3','M15-2','S04-2','S13-2','S14-2','S15-2')
END
SELECT @QCOUNT = COUNT(*) FROM Tmp_QualityDatas WHERE EngineSerialNo = @EngineSerialNo
SELECT @TCOUNT,@QCOUNT
IF @QCOUNT < @TCOUNT
BEGINSELECT @QCOUNT = COUNT(*) FROM (SELECT * FROM Trn_QualityDatas UNION ALL SELECT * FROM Tmp_QualityDatas) A WHERE EngineSerialNo = @EngineSerialNo
END
SELECT @TCOUNT,@QCOUNT
IF @QCOUNT < @TCOUNT SET @Result = 21
RETURN @Result
SET NOCOUNT OFF;
END

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

菲律宾的区块链和NFT市场调研

菲律宾的区块链和NFT市场调研 基本介绍 参考&#xff1a; https://zh.wikipedia.org/wiki/%E8%8F%B2%E5%BE%8B%E5%AE%BE zheng治制度&#xff1a;Zongtong议会制 现任Zongtong&#xff1a; 小费迪南德马科斯, 是独裁者费迪南德马科斯之子&#xff0c;人称“小马科斯” 官方语言…

【动态map】牛客挑战赛67 B

登录—专业IT笔试面试备考平台_牛客网 题意&#xff1a; 思路&#xff1a; 考虑动态的map 可以先定义一个状态&#xff0c;然后用map统计前缀这个状态的出现次数 在这里&#xff0c;定义{a,b}为cnt1 - cnt0和cnt2 - cnt0 当cnt0 和 cnt1都和cnt2相同时&#xff0c;统计贡献…

oracle 增加控制文件

oracle 增加控制文件 1、看control_file路径 SQL> show parameter controlNAME TYPE VALUE ------------------------------------ ----------- ------------------------------ control_file_record_keep_time integer …

Kubernetes kubectl管理命令使用方法

陈述式资源管理方法&#xff08;通过命令行&#xff09; 1.kubernetes 集群管理集群资源的唯一入口是通过相应的方法调用 apiserver 的接口 2.kubectl 是官方的CLI命令行工具&#xff0c;用于与 apiserver 进行通信&#xff0c;将用户在命令行输入的命令&#xff0c;组织并转化…

从零开始学python(十六)爬虫集群部署

前言 今天讲述Python框架源码专题最后一个部分&#xff0c;爬虫集群部署&#xff0c;前面更新了十五个从零开始学python的系列文章&#xff0c;分别是&#xff1a; 1.编程语法必修篇 2.网络编程篇 3.多线程/多进程/协程篇 4.MySQL数据库篇 5.Redis数据库篇 6.MongoDB数据库篇 …

运维监控学习笔记2

硬件监控&#xff1a; 1&#xff09;使用IPMI 2&#xff09;机房巡检 路由器和交换机&#xff1a; 使用SNMP&#xff08;简单网络管理协议&#xff09;进行监控。 Linux 安装snmp&#xff1a; yum install -y net-snmp net-snmp-utils 说明&#xff1a;net-snmp是安装在snm…

到 2030 年API 攻击预计将激增近 1000%

导读云原生应用程序编程接口管理公司 Kong 联合外部经济学家的最新研究预计&#xff0c;截至 2030 年 API 攻击将激增 996%&#xff0c;意味着与 API 相关的网络威胁的频率和强度都显着升级。 这项研究由 Kong 分析师和布朗大学副教授 Christopher Whaley 博士合作进行&#x…

StarGANv2: Diverse Image Synthesis for Multiple Domains论文解读及实现(一)

StarGAN v2: Diverse Image Synthesis for Multiple Domainsp github:https://github.com/clovaai/stargan-v2 1 模型架构 模型主要架构由四部分组成 ①Generator、②Mapping network、③Style encoder、④Discriminator Generator&#xff1a;G网络 生成模型G将输入图片x转换…

【软件测试】UI自动化框架,数据驱动 vs 关键字驱动怎么选

一、UI自动化测试用例剖析 让我们先从分析一端自动化测试案例的代码开始我们的旅程。以下是我之前写的一个自动化测试的小Demo。这个Demo基于Selenium与Java。 自动化测试小Demo 它要测试的东西其实是要看一下百度搜索能不能返回兴业银行的官网。我们分析一下这段代码都包含些…

清除pip安装库时的缓存

目录 1、命令清除缓存 2、路径手动清除 在使用pip安装Python库时&#xff0c;如果之前已经下载过该库&#xff0c;pip会默认使用缓存来安装库&#xff0c;而不是重新从网络上下载。缓存文件通常存储在用户目录下的缓存文件夹中&#xff0c;具体位置因操作系统和Python版本而异…

项目管理师基础之项目管理计划和项目文件

项目管理过程中&#xff0c;会使用并产生两大类文件&#xff1a;项目管理计划和项目文件。内容一般如下&#xff1a; 整个项目生命周期需要收集、分析和转化大量的数据。从各个过程收集项目数据&#xff0c;并在项目团队内共享。在各个过程中所收集的数据经过结合相关背景的分…

MySQL中同比和环比语句如何写?

营收表如下&#xff08;表名&#xff1a;a&#xff09;如下图&#xff1a; 营收表 year month money 2021 1 1000 2021 2 1200 2022 1 1300 2022 2 1500 需要算出2022年营收同比与环比&#xff1a; 同比&#xff1a;和去年同月相比&#xff08;1300-1000/1000*100%&#xff0…

简单易用且高效的跨平台开发工具:Xojo 2023 for Mac

Xojo for Mac是Mac平台上一个跨平台的针对桌面、Web、移动和Raspberry Pi的快速应用程序开发软件。与其他多平台开发工具相比&#xff0c;Xojo for Mac为开发人员提供了显着的生产率提高。 Xojo for Mac具有拖放功能&#xff0c;使您能够快速创建用户界面设计&#xff0c;然后…

算法随笔:图论问题之割点割边

割点 定义 割点的定义&#xff1a;如果一个点被删除之后会导致整个图不再是一个连通图&#xff0c;那么这个顶点就是这个图的割点。举例&#xff1a; 上图中的点2就是一个割点&#xff0c;如果它被删除&#xff0c;则整个图被分为两个连通分量&#xff0c;不再是一个连通图。…

【交换排序】冒泡排序 与 快速排序

交换排序基本思想&#xff1a; 所谓交换&#xff0c;就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置&#xff0c;交换排序的特点是&#xff1a;将键值较大的记录向序列的尾部移动&#xff0c;键值较小的记录向序列的前部移动。 目录 1.冒泡排序 2.快…

Django笔记之数据库函数之日期函数

日期函数主要介绍两个大类&#xff0c;Extract() 和 Trunc() Extract() 函数作用是提取日期&#xff0c;比如我们可以提取一个日期字段的年份&#xff0c;月份&#xff0c;日等数据 Trunc() 的作用则是截取&#xff0c;比如 2022-06-18 12:12:12&#xff0c;我们可以根据需求…

CSS:弹性盒子模型详解(用法 + 例子 + 效果)

目录 弹性盒子模型flex-direction 排列方式 主轴方向换行排序控制子元素缩放比例缩放是如何实现的&#xff1f; 控制子元素的对其方式justify-content 横向 对齐方式align-items 纵向 对齐方式 align-content 多行 对齐方式 弹性盒子模型 flex-direction 排列方式 主轴方向 f…

CI+JUnit5并发单测机制创新实践

目录 一. 现状问题 二. 分析原因 三. 采取措施 四. 实践步骤 五. 效能提升 资料获取方法 一. 现状问题 针对现如今高并发场景的业务系统&#xff0c;“并发问题” 终归是必不可少的一类&#xff08;占比接近10%&#xff09;&#xff0c;每次出现问题和事故后&#xff0c…

CNN经典网络模型之GoogleNet论文解读

目录 1. GoogleNet 1.1 Inception模块 1.1.1 1x1卷积 1.2 辅助分类器结构 1.3 GoogleNet网络结构图 1. GoogleNet GoogleNet&#xff0c;也被称为Inception-v1&#xff0c;是由Google团队在2014年提出的一种深度卷积神经网络架构&#xff0c;专门用于图像分类和特征提取任…

ElasticSearch安装与启动

ElasticSearch安装与启动 【服务端安装】 1.1、下载ES压缩包 目前ElasticSearch最新的版本是7.6.2&#xff08;截止2020.4.1&#xff09;&#xff0c;我们选择6.8.1版本&#xff0c;建议使用JDK1.8及以上。 ElasticSearch分为Linux和Window版本&#xff0c;基于我们主要学习…