《数据库开发实践》之存储过程【知识点罗列+例题演练】

2023-12-28 18:20

本文主要是介绍《数据库开发实践》之存储过程【知识点罗列+例题演练】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、什么是存储过程?

1.概念理解:

存储过程是一组为了完成特定功能的SQL语句集。通过组成SQL语句和控制语句,提供一种封装任务的方法。因此在创建编译好某个存储过程后,因为存储过程中有可执行操作的sql语句,用户可以根据需求,调用该过程时输入参数即可执行。简单一点理解,也就是相当于我们在JAVA里面写的代码一样,封装好 某个类、方法,这样在需要这个方法的时候就去调用其,就不用再重新又写、反复写。

2.存储过程的优点:

(1)模块化的程序设计
(2)在服务器端运行,具有高效率的执行力
(3)减少网络流量,存储过程在编译后,也就是要在执行一次之后,它的执行规划就会保留在高速缓冲存储器中,用户在后期调用该存储过程时,后台便只需从高速缓冲存储器中调用编译好的二进制代码,提高了系统性能
(4)确保数据库的安全,防止了用户暴露数据库表的细节,可以作为安全机制使用  

3.存储过程的分类:

  • 系统存储过程
  • 用户自定义存储过程

二、Mysql语句创建、执行和删除存储过程

1.创建存储过程

创建时需要事先确定存储过程的三个组成部分:

(1).所有的输入参数以及传给调用者的输出参数。
(2).被执行的针对数据库的操作语句,包括调用其他存储过程的语句。
(3).返回给调用者的状态值以指明调用是成功还是失败。

(1) 创建语法格式:

CREATE PROCEDURE 存储过程名 ([参数 ... ])
[特征 ...]  存储过程体 
a.参数=:[ IN | OUT | INOUT ] 参数名 参数类型
  • 参数的命名不要与所联系的数据表的列名出现相同的
  • 有多个参数的时候,要用逗号隔开
IN类型——输入参数可以使数据传递给存储过程
OUT类型——输出参数当需要返回一个结果时使用
INOUT类型——输入/输出参数两者都可以充当
b.特征=:LANGUAGE SQL  | [NOT] DETERMINISTIC  | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }  | SQL SECURITY { DEFINER | INVOKER }  | COMMENT 'string'
特征对应内容
LANGUAGE SQL存储过程的语言为SQL
[NOT] DETERMINISTIC存储过程是否确定性,即存储过程对同样的输入参数产生的结果是否相同
CONTAINS SQL[默认选项] 存储过程的子程序包含SQL语句,但是不包含读、写数据的语句
NO SQL存储过程中不包含SQL语句
READS SQL DATA存储过程只读取SQL数据
MODIFIES SQL DATA存储过程只修改SQL数据
SQL SECURITY { DEFINER | INVOKER }

存储过程执行的身份者指定

  • DEFINER:默认。创建该存储过程的用户许可
  • INVOKER:使用存储过程的用户许可
COMMENT 'string'存储过程的描述备注,string是描述的内容。使用SHOW CREATE PROCEDURE 就可以显示该信息
c.存储过程体:存储过程的主体部分,包含了调用存储过程时必会执行的SQL语句。
  • 开始标志是BEGIN,结束标志是END,只有 一条SQL语句时可以省略开始和结束标志;
  • 还需要注意的一个点是,因为存储过程里面的SQL语句是以分号结尾的,所以服务器在处理程序的时候遇到第一个分号就会以为要结束程序了,所以需要我们使用“Delimiter 结束符号”命令将Mysql语句的结束标志更改一下,编译后再恢复分号结束标志。

2.修改存储过程特征

MySQL只能通过ALTER语句修改存储过程的特征,不能修改存储过程体的内容,如需修改存储过程体的内容,需要先删除存储过程再重新创建

3.查看存储过程

show procedure status [like 'pattern']; 

其中,like 'pattern'为可选参数,用来匹配存储过程的名称,如果不指定该参数,则会查看所有的存储过程。

4.调用执行存储过程

call sp_name[(传参)];    

其中,sp_name为所执行的存储过程名称,传参表示根据存储过程定义时的参数进行传参。

5.删除存储过程

drop procedure [if exists] 存储过程名;

三、异常处理

(1)MySQL定义异常捕获类型及处理方法的语法如下:

DECLARE handler_action HANDLER  FOR condition_value [, condition_value] ...  statement  handler_action:  CONTINUE | EXIT  | UNDO        condition_value:  mysql_error_code  | SQLSTATE [VALUE] sqlstate_value  | condition_name|SQLWARNING|NOT FOUND| SQLEXCEPTION 

a.HANDLER  :异常关键词

b.FOR:声明

c.statement:表示出现某种条件、错误的时候需要执行的语句

  • 可以是简单的一句SQL语句
  • 可以是复杂的多行语句——这里就需要用起始标签Begin和结束标签End

d.hander_action:异常类型,表示执行完statement后希望系统执行什么动作

  • CONTINUE | EXIT  | UNDO        
  • continue:程序继续——SQL WARNING和NO FOUND 的默认处理方法
  • exit:跳出程序——SQLEXCEPTION的默认处理方法
  • undo:程序回滚,撤销

d.condition_value:表示一个异常处理可以定义成针对多种情况进行相应的操作

condition_value内容
mysql_error_codeMySQL错误码,一个由mysql自定义的数字
SQLSTATE[VALUE] sqlstate_valueSQL状态码,一个由五个字符组成的字符串
condition_name条件名称,使用declare...condition语句定义
SQLWARNINGSQL警告,表示SQLSTATE中字符串以‘01’起始的错误
NOT FOUND找不到,表示SQLSTATE中字符串以‘02’起始的错误
SQLEXCEPTION

SQL异常,表示SQLSTATE中字符串不以‘00’,‘01’,‘02’起始的错误

其中,‘00’是表示成功执行。

四、例题演练

1.创建一个存储过程p_yg1:

实现根据传入参数部门名称可以查询各部门所有员工的员工编号,员工姓名和职务。并调用此存储过程查询“技术”部门员工的员工编号,员工姓名和职务

delimiter //
create  procedure p_yg1( IN departmentName varchar(30))
begin
select  ygxx.ygbh,ygxx.name,ygxx.zw from ygxx inner join  bmxx on ygxx.ssbmbh=bmxx.bmbh  where bmxx.bmmc=departmentName;
end //
delimiter;

1)创建存储过程p_yg1 

 (2)调用存储过程p_yg1

2.创建一存储过程p_intsp1:

  • 通过带参数的存储过程向表spxx中插入一条数据,传入参数为spbh,spmc,sslb,jg,sl
  • 如果插入主键重复数据(错误号1062),则将spbh和spmc插入错误记录表splog中
  • 数据插入时间赋为当前日期,操作标志位赋上'insert'。
DELIMITER //
CREATE PROCEDURE p_intsp1 (IN spbh VARCHAR(20), IN spmc VARCHAR(30), IN sslb VARCHAR(20), IN jg DOUBLE, IN sl INT)
BEGINDECLARE t_error INTEGER DEFAULT 0;DECLARE CONTINUE HANDLER FOR 1062 SET t_error = 1;INSERT INTO spxx (spbh, spmc,sslb, jg, sl) VALUES (spbh, spmc,sslb, jg, sl);IF t_error = 1 THENINSERT INTO splog (spbjlog, spmclog, sjlog, bz) VALUES (spbh, spmc, NOW(), 'insert');ELSE COMMIT;END IF;END //
DELIMITER ;

(1)创建存储过程p_intsp1

(2)调用存储过程

a.展示当前的商品信息表和记录表

b.插入一条数据,重复了主键id
c.此时商品信息表没有新数据插入,记录log表插入新数据

这篇关于《数据库开发实践》之存储过程【知识点罗列+例题演练】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou