0010 数据库对象—存储过程

2024-09-01 16:32

本文主要是介绍0010 数据库对象—存储过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

存储过程概念

存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可独立执行或由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。存储过程一旦创建,在服务器上即被编译,可以在需要时执行多次,有效的提高了执行效率。

 

存储过程的分类:系统存储过程和用户存储过程 。

系统存储过程存储在master数据库中,且以sp_为前缀。在其他数据库中可以直接调用,不必指明数据库名

 

存储过程的优点

可以在单个存储过程中执行一系列 SQL 语句。

可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。

 

和函数的区别

执行的本质都一样。函数的限制比较多。具体如下;

1、返回值:函数只能返回值或者表对象而且是一个;而存储过程可以返回参数,返回单个或多个结果集以及返回值。

 

2、调用:函数是可以作为查询语句的一个部分来调用,所以可以嵌入在sql中使用,可以在select中调用;

             由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面;

              而存储过程作为一个独立的部分来执行。

 

3、数据来源;函数不能用临时表,只能用表变量;而存储过程的限制相对就比较少 。

 

实现功能:存储过程实现的功能要复杂一点;而函数的实现的功能针对性比较强。

 

主要讲用户存储过程的操作和调用

 管理存储过程的操作

1、创建存储过程:创建一个和创建一组。

步骤:1、判断存储过程是否存在,若存在,先删除存储过程。

          2、创建存储过程。

 

语法:(1)创建一个存储过程

                    if exists (sql语句)

                   Drop procedure  proname

                   Go

                   '开始创建

                   Create procedure proname  [参数列表(参数名,数据类型,默认值)[output]]

                   [with  recompile|encryption]

                   As<sql语句序列>

        (2)创建一组存储过程。用一个例子来说明吧!

使用“;”和 数字来创建了一组存储过程。

执行时,可以单独执行其中的一个,写明存储过程名,分号,和数字。例:execute group_sp;3

但是不可以单独删除某个存储过程,要删除只能一起删除。

 

         2、修改存储过程:只把定义中的create改成alter即可。

 

         3、删除存储过程:drop  procedure  proname

 

         4、查看存储过程:sp_helptext <存储过程名>    查看存储过程的文本,

                              sp_depends <对象名>          查看存储过程的饮用对象。

                              sp_help  显示所有相关信息。

         5、重命名存储过程:sp_rename  '<原名>','<新名>'

 

 

调用存储过程

         调用、参数传入、返回值。

               调用:使用语句execute。

 

              参数传入;按位传入:按照声明时的顺序传入;

                                按引用传入:按照参数的名字传入,书写参数时可一不安顺序来写。

              返回值:return 和output

两者没有区别:只是声明不同。return出现在定义完存储过程后。Return @变量名

而output是在创建存储过程定义变量时,写在要变量之后: @变量名  output

 

注意:1、参数变量前都需要加@。

             2、调用时,如果存储过程是批处理的第一条语句,可以不使用execute关键字,直接用存储过程铭来执行。

           3、传值时,@变量名=default或者不写,使用定义时的默认值。

          4、两种传值方式不可以混用。

 

触发器时特殊的存储过程,触发器是由事件触发的,而存储过程是单独执行或由程序调用的。

这篇关于0010 数据库对象—存储过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127466

相关文章

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs