存储过程到底是什么

刘梦阳的博客 刘梦阳的博客     2022-08-20     618

关键词:

在大型数据库系统中,存储过程和触发器具有很重要的作用。无论是存储过程还是触发器,都是sql 语句和流程控制语句的集合。就本质而言,触发器也是一种存储过程。存储过程在运算时生成执行方式,
所以,以后对其再运行时其执行速度很快。sql server 2000 不仅提供了用户自定义存储过程的功能,而且也提供了许多可作为工具使用的系统存储过程。 12.1.1 存储过程的概念 存储过程(stored procedure)是一组为了完成特定功能的sql 语句集,经编译后存储在数据库。中用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。 在sql server 的系列版本中存储过程分为两类:系统提供的存储过程和用户自定义存储过程。系统过程主要存储在master 数据库中并以sp_为前缀,并且系统存储过程主要是从系统表中获取信息,
从而为系统管理员管理sql server 提供支持。通过系统存储过程,ms sql server 中的许多管理性或信息性的活动(如了解数据库对象、数据库信息)都可以被顺利有效地完成。尽管这些系统存储过程
被放在master 数据库中,但是仍可以在其它数据库中对其进行调用,在调用时不必在存储过程名前加上数据库名。而且当创建一个新数据库时,一些系统存储过程会在新数据库中被自动创建。用户自定义存
储过程是由用户创建并能完成某一特定功能(如查询用户所需数据信息)的存储过程。在本章中所涉及到的存储过程主要是指用户自定义存储过程。 12.1.2 存储过程的优点 当利用ms sql server 创建一个应用程序时,transaction-sql 是一种主要的编程语言。若运用transaction-sql 来进行编程,有两种方法。其一是,在本地存储transaction- sql 程序,并
创建应用程序向sql server 发送命令来对结果进行处理。其二是,可以把部分用transaction-sql 编写的程序作为存储过程存储在sql server 中,并创建应用程序来调用存储过程,对数据结果进行处
理存储过程能够通过接收参数向调用者返回结果集,结果集的格式由调用者确定;返回状态值给调用者,指明调用是成功或是失败;包括针对数据库的操作语句,并且可以在一个存储过程中调用另一存储过程
。 我们通常更偏爱于使用第二种方法,即在sql server 中使用存储过程而不是在客户计算机上调用transaction-sql 编写的一段程序,原因在于存储过程具有以下优点: (1) 存储过程允许标准组件式编程 存储过程在被创建以后可以在程序中被多次调用,而不必重新编写该存储过程的sql 语句。而且数据库专业人员可随时对存储过程进行修改,但对应用程序源代码毫无影响(因为应用程序源代码只包含存储过
程的调用语句),从而极大地提高了程序的可移植性。 (2) 存储过程能够实现较快的执行速度 如果某一操作包含大量的transaction-sql 代码或分别被多次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,
并给出最终被存在系统表中的执行计划。而批处理的transaction- sql 语句在每次运行时都要进行编译和优化,因此速度相对要慢一些。 (3) 存储过程能够减少网络流量 对于同一个针对数据数据库对象的操作(如查询、修改),如果这一操作所涉及到的 transaction-sql 语句被组织成一存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句
,否则将是多条sql 语句,从而大大增加了网络流量,降低网络负载。 (4) 存储过程可被作为一种安全机制来充分利用 系统管理员通过对执行某一存储过程的权限进行限制,从而能够实现对相应的数据访问权限的限制,避免非授权用户对数据的访问,保证数据的安全。(我们将在14 章“sqlserver 的用户和安全性管理”中
对存储过程的这一应用作更为清晰的介绍) 注意:存储过程虽然既有参数又有返回值,但是它与函数不同。存储过程的返回值只是指明执行是否成功,并且它不能像函数那样被直接调用,也就是在调用存储过程时,在存储过程名字前一定要有exec保
留字(如何执行存储过程见本章下一字)。

  

springboot到底是什么?

...,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。本文分享自华为云社区《​​SpringBoot到底是什么?如何理解parent、starter、引导类以及内嵌Tomcat?​​》,作者:我是一棵卷心菜。SpringBoot是由Pivotal团队提供的全... 查看详情

消息队列---rocketmq-消息存储1(代码片段)

...们将在学习过程中逐渐寻找答案。概述本文将会走完文件存储的主体流程,后续分析各个重要的类。源码分析消息持久化几个重要的类:DefaultMessageStorecommitLogMappedFileDefaultMessageStore持有commitLog,commitLog持有MappedFileQueue,MappedFileQu... 查看详情

聊聊计算和存储分离

1.背景这篇文章是我一直想写的一篇,因为“计算和存储分离”最近几年在大家的视野中出现得越来越多,但其实很多对于其到底代表着什么也是模糊不清,这里我查阅了很多的资料再结合平时自己的理解,聊聊到底什么是“计... 查看详情

Rails 3.0 中的 Arel 到底是啥?

...询吗?它将与所有主要数据库兼容吗?-我想会的。使用存储过程会更容易/更难吗?【 查看详情

r语言中的factor到底是什么?(代码片段)

...sp; 因子(factors)是用于对数据进行分类(categorize)并将其存储为不同水平或者级别(levels)的数据对象。它们既可以存储字符串,也可以存储整数。Factors的唯一值是有限的。像“男”、“女”和“真”、“假”等,它们在统计建模... 查看详情

什么是存储过程?用什么来调用?

存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。可以用一个命令对象来调用存储过程。 查看详情

存储过程

了解新事物需要问的问题:什么是存储过程?什么时候用存储过程?存储过程是什么样的?怎么调用存储过程?  什么时候用存储过程?当逻辑复杂的时候,当一条sql表达不出来的时候,当sql很复杂的时候,当要执行一堆... 查看详情

补码到底是个什么东西(代码片段)

...sp;概述先引入一个前提,在计算机中数字是以二进制进行存储的,也就是我们看到的2,在计算机中存储的是10。我们进行的加法运算2+1=3在计算机中是这样的(这里先假设计算机存储的是4位二进制数字)0010+0001=0011很容以看的出... 查看详情

plsqldeveloper编辑存储过程未响应

如题,编译好的存储过程,我修改了一下,然后再执行每次执行后,就一直显示正在编译,任务管理器里面显示未响应...重启电脑也没有用,不知道到底是什么原因,该如何解决,请教下各位高手!!这事我也遇到过,尤其是cre... 查看详情

到底什么是es索引?

你会发现,其实在ES里面,索引扮演的角色其实并不是存储,而是“索引”,看起来有点傻,但是其实我之前一直理解索引是存储,其实从命名上可以看出来,索引其实是分片的索引,分片的字典,记录了每个分片的位置,索引... 查看详情

什么是存储过程?有什么优点?

存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。优点:1、重复使用:存储... 查看详情

关于this的指向问题及new的过程到底发生了什么

关于这个this的问题,我也是百度了很多,其中不乏有好文章,但是每个人都有自己不懂得那个点在那里,有时候就是感觉get不到关键问题所在,以下是我个人认为最影响我理解的一些地方,可以参考一下。 1.this到底用在什... 查看详情

12_什么是存储过程?

如何创建存储过程?      createprocedure名字()   begin.......end        .......中写入对数据库的操作      --调用存储过程&nbs 查看详情

filecoin官方亲自站台并高度评价!web3.storage到底是什么?

...0c;Filecoin官方利用社交媒体正式发声:Web3.Storage,存储数据上Filecoin最简单的方法。亲自站台并且高度评价,足见Filecoin官方对Web3.Storage寄予厚望,那么Web3.Storage到底是什么呢?它在Filecoin以及IPFS普及过程中又... 查看详情

西部世界:fil减产绝非存储服务商收益“减产”,所以“减产”到底是什么?

​​大家近期一直在问西部世界,FIL真的要减产吗?那会不会对我收益有影响呀,我每天都在wakuang,是不是减产我的产币也会跟着变少,各种疑惑,因为FIL发展历程对于绝大部分人都是不清楚,只知道... 查看详情

在 SQL Server 存储过程中将 varchar 转换为 int 时出错

】在SQLServer存储过程中将varchar转换为int时出错【英文标题】:ErrorconvertingvarchartointinSQLServerstoredprocedure【发布时间】:2013-10-3114:22:05【问题描述】:以下是我的存储过程。我收到一个错误,但我不明白到底是什么问题CREATEProc[dbo]... 查看详情

请问oracle怎么执行存储过程

语法是什么:exec存储过程名(参数)execute存储过程名(参数)存储过程名(参数)都不行,到底怎么调用啊使用oracle调用存储过程得方式和plsql不一样,下面给你个调用例子过程调用方式一declarerealsalemp.sal%type;realnamevarchar(40);realjob... 查看详情

数据库存储过程是啥

参考技术A问题一:sql数据库中的存储过程该怎么理解有什么用啊?存储过程是SQL语句和流程控制语句的预编译***,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序调用执行,而且允许用户声明变... 查看详情