Mysql存储过程基本语法

目录

  • 存储过程
    • MYSQL
      • 基础语法
      • 游标(作用范围存储过程)
      • 事务(Demo)
      • 其他操作
      • Demo

存储过程

MYSQL

基础语法

#创建存储过程
#参数格式
#in输入参数  out输出参数 inout既可以输入也可以输出  
create or replace procedure '存储过程名称'(in | out | inout arg varchar(255))#begin和end表示sql代码的开始与结束
begin#使用declare来声明变量declare age int default 18;declare name varchar(255) default '雄狮';declare code int;declare num int;#使用set对定义的变量赋值set code = 0;#使用运算符对变量进行合法运算,将结果赋值给变量`set 变量名 :=expression(表达式)`set age :=age+20;#控制结构if age > 18 thenselect '成年';elseselect '未成年';end if;#循环结构(while结构)while age > 0 doset age := age - 1;end while;#循环结构(repeat结构)repeatset age := age - 1;until age < 0end repeat;#循环结构(for结构)#循环结构(loop结构)#case结构set num := mod(age,2);case numwhen 1 then select '我是奇数';when 2 then select '我是偶数';else select 'I donot know';end case;
end

游标(作用范围存储过程)

#声明游标(定义游标选项、要查询的select语句)
declare cursor_student cursor for select id from student;
#打开游标,使用游标数据(前面定义的select语句检索出来)
open cursor_student;
#从游标中取数据,获取第一行数据
fetch cursor_student into result;
#关闭游标
close cursor_student;

事务(Demo)

#将结束符号 改成 ;; 结束
DELIMITER ;;
#创建一个存储过程,名称是pre_affair ,输入变量是 in_user_name 字符串型 ,输出变量是out_rest 整形
CREATE PROCEDURE `pre_affair`(IN in_user_name VARCHAR(255), OUT out_rest INT)
BEGIN#定义一个循环变量i,类型是整形,默认是5DECLARE i INT DEFAULT 5;#定义一个错误的变量,类型是整形,默认是0DECLARE t_error INTEGER DEFAULT 0;#捕获到sql的错误,就设置t_error为1DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error=1;#开启事务START TRANSACTION;#删除id是5的这条数据DELETE FROM `user` WHERE id = 5;#循环插入数据,这里是从 id是5插入到id是6为止#注意:这里user表的id是5的这条被删除了,因为id是主键,但是id是6的这条本身存在,如果这里插入id是6时,将会发生事务回滚,id是5的这条不会被删除WHILE i<7 DO#插入一条数据进来INSERT INTO `user`(id,user_name)VALUES(i,in_user_name);#设置i每次循环加1SET i = i + 1;END WHILE;#如果捕获到错误IF t_error=1 THEN#回滚ROLLBACK;ELSE#提交COMMIT;END IF;#查看返回的结果,并给到输出的变量中SELECT t_error INTO out_rest;
END
;;
#将结束符号 改成 ; 结束
DELIMITER ;

其他操作

#删除存储过程(注意:不能在一个存储过程中删除另一个存储过程)
drop procedure '存储过程名称'#区块
begin#sql语句
end;
#区块别名
lable:begin#sql语句
end lable;
#跳出区块,执行区块之后的代码
leave lable;#显示数据库中所有存储的存储过程基本信息
show procedure status;#显示某一个存储过程的详细信息
show create procedure '存储过程名称';#修改mysql默认结束符,将默认结束符';' 改为 '$$'
#目的就是为了防止mysql解释器在我们编写存储过程时就执行sql,mysql解释器认为';'号就是sql结束符
DELIMITER $$DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET flag=true;
#MySQL continue handler 是一种用于处理游标的异常情况的方法。当使用游标进行数据遍历时,如果产生了异常,比如数据没有找到或者游标已经到达了末尾,continue handler 可以帮助我们捕获这些异常并执行相应的操作

Demo

#创建存储过程
CREATE DEFINER=`root`@`localhost` PROCEDURE `user_demo_one`(in arg1 VARCHAR(255),out arg2 VARCHAR(255))
BEGINselect id into arg2 from student where create_by = arg1;
END#调用存储过程
call user_demo_one('小A',@arg2);
select @arg2;#创建游标
CREATE DEFINER=`root`@`localhost` PROCEDURE `user_demo_one`()
BEGINdeclare result varchar(255);declare flag boolean default false;declare cursor_student cursor for select id from student;#MySQL continue handlerDECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET flag=true;#打开游标open cursor_student;repeat #获取第一行数据fetch cursor_student into result;until flag end repeat;select result;close cursor_student;
end

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

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

相关文章

react常用知识点

React是一个用于构建用户界面的JavaScript库。以下是React常用的知识点&#xff1a; 组件&#xff1a;React将用户界面分解成小而独立的组件&#xff0c;每个组件都有自己的状态和属性&#xff0c;并且可以通过组合这些组件来构建复杂的用户界面。 // 函数组件示例 function We…

torch.load 报错 ModuleNotFoundError 或 AttributeError

Python 3.11.3 (main, Apr 7 2023, 19:25:52) [Clang 14.0.0 (clang-1400.0.29.202)] on darwin Type "help", "copyright", "credits" or "license" for more information.正常情况下&#xff0c;我们会使用 torch.save 保存模型的 …

向 Maven 中央仓库上传一个修改过的基于jeecg的autoPOI的 jar包记录

1、注册https://issues.sonatype.org/账号 下面就代表注册好了&#xff0c;同时提交的工单也通过了 2、这里主要是goupId 需要进行认证&#xff0c;需要到域名注册商近一个txt的解析&#xff0c;以便确保这个是你的 通过下面来验证你的域名信息&#xff0c;这里主要是上面的工…

git命令分类合集

配置 git config --global user.name <name>&#xff1a;设置全局用户名 git config --global user.email <email>&#xff1a;设置全局用户邮箱 git config --global core.editor <editor>&#xff1a;设置全局文本编辑器创建与克隆仓库 git init&#xf…

面试题:说一说深拷贝和浅拷贝?

JavaScript中存在两大数据类型&#xff1a; 基本类型 和 引用类型 基本类型数据保存在在栈内存中 引用类型数据保存在堆内存中&#xff0c;引用数据类型的变量是一个指向堆内存中实际对象的引用&#xff0c;存在栈中 深拷贝和浅拷贝都只针对于引用类型。 一、 浅拷贝&#xff1…

【2023年11月第四版教材】《第1章-信息化发展之<3 现代化创新发展>》

第1章-信息化发展之&#xff1c;3 现代化创新发展&#xff1e; 3 现代化创新发展3.1 农业现代化3.2 两化融合&#xff08;17下2&#xff09;&#xff08;18下2&#xff09; &#xff08;22下12)3.3 智能制造3.4 消费互联网 3 现代化创新发展 3.1 农业现代化 要素具体内容农业…

Cpp7 — 继承和多态

继承 -------- 面向对象的三大特性之一 面向对象的三大特性&#xff1a;封装、继承、多态 封装&#xff1a;把数据和方法都封装在一起&#xff0c;想给你访问的变成共有&#xff0c;不想给访问的&#xff0c;写成私有。 继承&#xff1a;继承是类设计层次的复用 多态&#…

[SQL挖掘机] - 索引

介绍: 当你在数据库中进行查询时&#xff0c;索引是一种用于提高查询性能的重要工具。索引是对表中的一列或多列进行排序的数据结构&#xff0c;它可以快速定位到满足特定条件的记录&#xff0c;从而减少了查询所需的时间和资源。 在数据库中使用索引的主要好处包括&#xff…

【AGI】Copilot AI编程辅助工具安装教程

1. 基础激活教程 GitHub和OpenAI联合为程序员们送上了编程神器——GitHub Copilot。 但是&#xff0c;Copilot目前不提供公开使用&#xff0c;需要注册账号通过审核&#xff0c;我也提交了申请&#xff1a;这里第一期记录下&#xff0c;开启教程&#xff0c;欢迎大佬们来讨论…

通向架构师的道路之apache性能调优

一、总结前一天的学习 在前两天的学习中我们知道、了解并掌握了Web Server结合App Server实现单向Https的这样的一个架构。这个架构是一个非常基础的J2ee工程上线布署时的一种架构。在前两天的教程中&#xff0c;还讲述了Http服务 器、App Server的最基本安全配置&#xff08;…

java 数组的使用

数组 基本介绍 数组可以存放多个同一类型的数据&#xff0c;数组也是一种数据类型&#xff0c;是引用类型。 即&#xff1a;数组就是一组数据。 数组的使用 1、数组的定义 方法一 -> 单独声明 数据类型[] 数组名 new 数据类型[大小] 说明&#xff1a;int[] a new int…

C/C++算法——散列表

1、散列表介绍 散列表的英文叫Hash Table&#xff0c;我们平时也叫它哈希表或者Hash 表。散列表用的是数组支持按照下标随机访问数据的特性&#xff0c;所以散列表其实就是数组的一种扩展&#xff0c;由数组演化而来。可以说&#xff0c;如果没有数组&#xff0c;就没有散列表。…

【SpringBoot】85、SpringBoot中Boolean类型数据转0/1返回序列化配置

在 SpringBoot 中,前端传参数 0,1,后端可自动解析为 boolean 类型,但后端返回前端 boolean 类型时,却无法自动转换为 0,1,所以我们需要自定义序列化配置,将 boolean 类型转化为 0,1 1、类型对应 boolean 类型有false,true对应的 int 类型0,12、序列化配置 import com.f…

iOS——锁与死锁问题

iOS中的锁 什么是锁锁的分类互斥锁1. synchronized2. NSLock3. pthread 递归锁1. NSRecursiveLock2. pthread 信号量Semaphore1. dispatch_semaphore_t2. pthread 条件锁1. NSCodition2. NSCoditionLock3. POSIX Conditions 分布式锁NSDistributedLock 读写锁1. dispatch_barri…

MySQL优化

目录 一. 优化 SQL 查询语句 1.1. 分析慢查询日志 1.2. 优化 SQL 查询语句的性能 1.2.1 优化查询中的索引 1.2.2 减少表的连接&#xff08;join&#xff09; 1.2.3 优化查询语句中的过滤条件 1.2.4 避免使用SELECT * 1.2.5 优化存储过程和函数 1.2.6 使用缓存 二. 优化表结构…

超全整理,Jmeter性能测试-常用Jmeter第三方插件详解(超细)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 Jmeter作为一个开…

React(4)

1.属性&#xff08;props&#xff09;初始 状态state都是组件内部写的&#xff0c;也就是A组件内的state就只能A组件里面用&#xff0c;其他组件复用不了。因此属性props就可以。 比如一个导航栏&#xff0c;首页有&#xff0c;购物车有&#xff0c;我的有&#xff0c;他们三个…

Vue使用QrcodeVue生成二维码并下载

生成二维码 1、安装qrcode.vue组件 npm install --save qrcode.vue<template><div id"app"><qrcode-vue :valuevalue :sizesize></qrcode-vue><br /></div> </template><script> //导入组件 import QrcodeVue fro…

《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(20)-Fiddler精选插件扩展安装让你的Fiddler开挂到你怀疑人生

1.简介 Fiddler本身的功能其实也已经很强大了&#xff0c;但是Fiddler官方还有很多其他扩展插件功能&#xff0c;可以更好地辅助Fiddler去帮助用户去开发、测试和管理项目上的任务。Fiddler已有的功能已经够我们日常工作中使用了&#xff0c;为了更好的扩展Fiddler&#xff0c…

P4780 Phi的反函数

题目 思路 φ(x)n 当指数均为1时n最小 证明&#xff1a;容斥原理 代码 #include<bits/stdc.h> using namespace std; #define int long long const int maxn1e9; int ansINT_MAX,n; bool f; map<int,bool> mp; bool is_prime(int n){if(n<1) return false;fo…