Java学习 - MySQL存储过程、函数和触发器练习实例
存储过程
-
存储过程是什么
存储过程是一组已经编译好的SQL语句
-
存储过程优点有什么
安全 性能高 提高代码复用性
-
创建存储过程的语法
DELIMITER $ # 不能加分号CREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 参数类型) BEGIN存储过程语句块 END;$DELIMITER ;
-
创建一个无参的存储过程:打印 myemployees 库中 employees 表中 employee_id = 168的first_name,并调用
DELIMITER $CREATE PROCEDURE myprocedure1() BEGINSELECT first_nameFROM employeesWHERE employee_id = 168; END;$DELIMITER ;CALL myprocedure1();
-
创建一个IN参数存储过程:打印传递进来的参数
DELIMITER $CREATE PROCEDURE myprocedure2(IN v INT) BEGINSELECT v; END;$DELIMITER ;SET @v = 10;CALL myprocedure2(@v);
-
创建一个IN参数和OUT参数存储过程:传递来一个变量 invalue = 10,输出一个变量 outvalue = invalue * 2
DELIMITER $CREATE PROCEDURE myprocedure3(IN invalue INT,OUT outvalue INT) BEGINSELECT invalue * 2 INTO outvalue; END;$DELIMITER ;SET @invalue = 10; SET @outvalue = 0;CALL myprocedure3(@invalue,@outvalue);SELECT @outvalue;
-
创建一个INOUT参数存储过程:传递进来一个数,令其变为10倍
DELIMITER $CREATE PROCEDURE myprocedure4(INOUT inoutvalue INT) BEGINSET inoutvalue = inoutvalue * 10; END;$DELIMITER ;SET @value = 10;CALL myprocedure4(@value);SELECT @value;
-
创建一个IN参数存储过程:输入一个数,如果大于0显示’greater than 0’,小于零显示’less than 0’,等于0显示’equals 0’
DELIMITER $CREATE PROCEDURE myprocedure5(IN target INT) BEGINSELECTCASEWHEN target > 0 THEN 'greater than 0'WHEN target = 0 THEN 'equalse 0'ELSE 'less than 0'ENDAS result; END;$DELIMITER ;CALL myprocedure5(-1); CALL myprocedure5(0); CALL myprocedure5(1);
-
创建一个IN参数和OUT参数存储过程:输入一个数,如果等于1显示’Hello’,等于2显示’World’,否则显示’Byebye’,结果同时保存到OUT参数中
DELIMITER $CREATE PROCEDURE myprocedure6(IN target INT,OUT result VARCHAR(20)) BEGINSELECTCASE targetWHEN target = 1 THEN 'Hello'WHEN target = 2 THEN 'World'ELSE 'ByeBye'ENDINTO result; END;$DELIMITER ;CALL myprocedure6(0,@ret1); CALL myprocedure6(1,@ret2); CALL myprocedure6(2,@ret3);SELECT @ret1,@ret2,@ret3;
-
创建一个无参的存储过程:循环打印 myemployees 库中 employees 表中 employee_id = 168的first_name3次
DELIMITER $CREATE PROCEDURE myprocedure5() BEGINDECLARE times INT DEFAULT 0;WHILE times < 3 DOSELECT first_nameFROM employeesWHERE employee_id = 168;SET times = times + 1;END WHILE; END;$DELIMITER ;CALL myprocedure5();
-
创建一个IN参数存储过程:输入一个正整数,打印它这么多次"This is REPEAT UNITL"
DELIMITER $CREATE PROCEDURE myprocedure6(IN times INT) BEGINREPEAT SELECT 'This is REPEAT UNTIL';SET times = times - 1;UNTIL times < 0 END REPEAT; END;$DELIMITER ;CALL procedure6(10);
-
创建一个OUT参数存储过程:返回1x2x3x…x10的结果给一个OUT参数result,使用LOOP循环
DELIMITER $CREATE PROCEDURE myprocedure7(OUT result INT) BEGINDECLARE times INT DEFAULT 1;SET result = 1;tt:LOOPSET times = times + 1;SET result = result * times;IF times > 10THEN LEAVE tt;END IF;END LOOP; END;$DELIMITER ;SET @result = 0;CALL myprocedure7(@result);SELECT @result;
-
查看有哪些存储过程
SHOW PROCEDURE STATUS;
-
查看存储过程myprocedure1的创建语句
SHOW CREATE PROCEDURE myprocedure1;
-
删除当前数据库中本次练习创建的存储过程
DROP PROCEDURE myprocedure1; DROP PROCEDURE myprocedure2; DROP PROCEDURE myprocedure3; DROP PROCEDURE myprocedure4; DROP PROCEDURE myprocedure5; DROP PROCEDURE myprocedure6; DROP PROCEDURE myprocedure7; DROP PROCEDURE myprocedure8; DROP PROCEDURE myprocedure9; DROP PROCEDURE myprocedure10;
函数
-
函数是什么,与存储过程的区别
类似存储过程,是一组编译好的SQL语句
-
函数与存储过程的区别
函数必须有返回值和return语句,参数形式为 参数名 参数类型,取消了参数模式 函数如果使用 SELECT,则必须配合INTO关键字,因为函数不允许出现结果集
-
函数优点是什么
增强代码复用性 将执行过程封装起来,增强安全性 因为是已经编译好的SQL语句,性能较高
-
创建函数的语法
DELIMITER $CREATE FUNCTION 函数名(参数名 参数类型) RETURNS 返回值类型 BEGIN函数体 END;$DELIMITER ;
-
函数能不要返回值,不要return语句吗
不行,必须要有返回值和return语句
-
创建一个无参的函数:用于查找 myemployees 库中 employees 表中 employee_id = 168的first_name
DELIMITER $CREATE FUNCTION myfunction1() RETURNS VARCHAR(30) BEGINDECLARE ret varchar(30);SELECT first_name INTO retFROM employeesWHERE employee_id = 168;RETURN ret; END;$DELIMITER ;SELECT myfunction1();
-
创建一个含参函数:接收传递进来的参数,返回这个参数与"-myfunction2"的拼接结果
DELIMITER $CREATE FUNCTION myfunction2(invar VARCHAR(30)) RETURNS VARCHAR(30) BEGINRETURN CONCAT(invar,'-myfunction2'); END;$DELIMITER ;SELECT myfunction2('abc');
-
创建一个含参函数:传递来一个变量 invalue = 10,返回 invalue * 2
DELIMITER $CREATE FUNCTION myfunction3(invalue INT) RETURNS INT BEGINRETURN invalue * 2; END;$DELIMITER ;SET @invalue = 10;SELECT myfunction3(@invalue);
-
创建一个含参函数:输入一个数,如果大于0返回’greater than 0’,小于零返回’less than 0’,等于0返回’equals 0’
DELIMITER $CREATE FUNCTION myfunction4(invalue INT) RETURNS VARCHAR(30) BEGINRETURN CASEWHEN invalue > 0 THEN 'greater than 0'WHEN invalue = 0 THEN 'equals 0'WHEN invalue < 0 THEN 'less than 0'END; END;$DELIMITER ;SELECT myfunction4(-1); SELECT myfunction4(0); SELECT myfunction4(1);
-
创建一个含参函数:输入一个数,如果等于1返回’Hello’,等于2返回’World’,否则返回’Byebye’
DELIMITER $CREATE FUNCTION myfunction5(invalue INT) RETURNS VARCHAR(30) BEGINRETURN CASE invalueWHEN invalue = 1 THEN 'Hello'WHEN invalue = 2 THEN 'World'ELSE 'ByeBye'END; END;$DELIMITER ;SELECT myfunction5(1); SELECT myfunction5(2); SELECT myfunction5(3);
-
创建一个无参函数:返回1+2+…+100的结果【使用while循环】
DELIMITER $CREATE FUNCTION myfunction6() RETURNS INT BEGINDECLARE times INT DEFAULT 0;DECLARE retsum INT DEFAULT 0;WHILE times < 101 DOSET retsum = retsum + times;SET times = times + 1;END WHILE;RETURN retsum; END;$DELIMITER ;SELECT myfunction6();
-
创建无参函数:返回1x2x3x…x10的结果【使用LOOP循环】
DELIMITER $CREATE FUNCTION myfunction7() RETURNS INT BEGINDECLARE times INT DEFAULT 1;DECLARE retsum INT DEFAULT 1;tt:LOOPSET retsum = retsum * times;SET times = times + 1;IF times > 10THEN LEAVE;END IF;END LOOP;RETURN retsum; END;$DELIMITER ;
-
查看所有的函数
SHOW FUNCTION STATUS;
-
查看函数myfunction1的创建语句
SHOW CREATE FUNCTION myfunction1;
-
删除本次练习所创建的所有函数
DROP FUNCTION myfunction1; DROP FUNCTION myfunction2; DROP FUNCTION myfunction3; DROP FUNCTION myfunction4; DROP FUNCTION myfunction5; DROP FUNCTION myfunction6; DROP FUNCTION myfunction7;
触发器
-
什么是触发器
一类特殊的事务,可以监视某种DML操作,并触发相关DML操作
-
创建触发器的语法
DELIMITER $CREATE TRIGGER 触发器名字 BEFORE|AFTER INSERT|UPDATE|DELETE ON 表名 FOR EACH ROW BEGIN触发器的DML语句 END$DELIMITER ;
-
创建两张表
goods:
商品主键 商品名 库存 1 电脑 28 2 自行车 12 orders:
订单主键 购买数量 商品外键 1 3 2 2 5 1 CREATE TABLE IF NOT EXISTS goods (g_id INT,g_name VARCHAR(20),g_count INT,CONSTRAINT pk PRIMARY KEY(g_id),CONSTRAINT uk UNIQUE(g_name) );INSERT INTO goods(g_id,g_name,g_count) VALUES (1,'电脑',28),(2,'自行车',12);CREATE TABLE IF NOT EXISTS orders (o_id INT PRIMARY KEY,o_count INT,o_g INT,CONSTRAINT fk_goods_g_id FOREIGN KEY(o_g) REFERENCES goods(g_id) );INSERT INTO orders(o_id,o_count,o_g) VALUES (1,3,2),(2,5,1);
-
创建触发器,让orders购买数量增多时,goods数量相应减少
DELIMITER $CREATE TRIGGER my_trigger AFTER UPDATE ON orders FOR EACH ROW BEGINUPDATE goodsSET g_count = g_count - (new.o_count - old.o_count)WHERE g_id = new.o_g; END;$DELIMITER ;
-
查看所有的触发器
SHOW TRIGGERS;
-
查看my_trigger的创建语句
SHOW CREATE TRIGGERS my_trigger;
-
删除my_trigger
DROP TRIGGER my_trigger;
相关文章:
Java学习 - MySQL存储过程、函数和触发器练习实例
存储过程 存储过程是什么 存储过程是一组已经编译好的SQL语句存储过程优点有什么 安全 性能高 提高代码复用性创建存储过程的语法 DELIMITER $ # 不能加分号CREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 参数类型) BEGIN存储过程语句块 END;$DELIMITER ;创建一个无参的存储…...
【深度神经网络 (DNN)】
深度神经网络 (DNN) 深度神经网络 (DNN) 是机器学习领域中一种强大的工具,它由多层神经元组成,能够学习复杂的数据模式,解决各种任务,如图像识别、语音识别、自然语言处理等。 DNN 的构成: 神经元: DNN 的基本单元&…...

ES全文检索支持繁简和IK分词检索
ES全文检索支持繁简和IK分词检索 1. 前言2. 引入繁简转换插件analysis-stconvert2.1 下载已有作者编译后的包文件2.2 下载源码进行编译2.3 复制解压插件到es安装目录的plugins文件夹下 3. 引入ik分词器插件3.1 已有作者编译后的包文件3.2 只有源代码的版本3.3 安装ik分词插件 4…...
解决Visual Studio Code在Ubuntu上崩溃的问题
解决Visual Studio Code在Ubuntu上崩溃的问题 我正在使用Ubuntu系统,每次打开Visual Studio Code时,只能短暂打开一秒钟,然后就会崩溃。当通过终端使用code --verbose命令启动Visual Studio Code时,出现以下错误信息:…...
【OpenGauss源码学习 —— (ALTER TABLE(SET attribute_option))】
ALTER TABLE(SET attribute_option) ATExecSetOptions 函数 声明:本文的部分内容参考了他人的文章。在编写过程中,我们尊重他人的知识产权和学术成果,力求遵循合理使用原则,并在适用的情况下注明引用来源。…...

Elasticsearch 数据提取 - 最适合这项工作的工具是什么?
作者:来自 Elastic Josh Asres 了解在 Elasticsearch 中为你的搜索用例提取数据的所有不同方式。 对于搜索用例,高效采集和处理来自各种来源的数据的能力至关重要。无论你处理的是 SQL 数据库、CRM 还是任何自定义数据源,选择正确的数据采集…...
‘浔川画板v5.1’即将上线!——浔川python社
1 简介: 浔川画板是一款专业的数字绘画和漫画创作软件,它为艺术家和设计师提供了丰富的绘画工具、色彩管理功能以及易于使用的界面。用户可以使用浔川画板进行手绘风格的绘画、精细的素描、漫画分格、UI设计等多种创作。该软件支持多种笔刷和特效&#…...

RockChip Android12 System之Datetime
一:概述 本文将针对Android12 Settings二级菜单System中Date&time的UI修改进行说明。 二:Date&Time 1、Activity packages/apps/Settings/AndroidManifest.xml <activityandroid:name="Settings$DateTimeSettingsActivity"android:label="@stri…...

详解 ClickHouse 的副本机制
一、简介 副本功能只支持 MergeTree Family 的表引擎,参考文档:https://clickhouse.tech/docs/en/engines/table-engines/mergetree-family/replication/ ClickHouse 副本的目的主要是保障数据的高可用性,即使一台 ClickHouse 节点宕机&#…...

速卖通测评成本低见效快,自养号测评的实操指南,快速积累销量和好评
对于初入速卖通的新卖家而言,销量和评价的积累显得尤为关键。由于新店铺往往难以获得平台活动的青睐,因此流量的获取成为了一大挑战。在这样的背景下,进行产品测评以积累正面的用户反馈和销售记录,成为了提升店铺信誉和吸引潜在顾…...

php反序列化漏洞简介
目录 php序列化和反序列化简介 序列化 反序列化 类中定义的属性 序列化实例 反序列化实例 反序列化漏洞 序列化返回的字符串格式 魔术方法和反序列化利用 绕过wakeup 靶场实战 修复方法 php序列化和反序列化简介 序列化 将对象状态转换为可保持或可传输的格式的…...

力扣随机一题 模拟+字符串
博客主页:誓则盟约系列专栏:IT竞赛 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ 1910.删除一个字符串中所有出现的给定子字符串【中等】 题目: …...
java-正则表达式 1
Java中的正则表达式 1. 正则表达式的基本概念 正则表达式(Regular Expression, regex)是一种用于匹配字符串中字符组合的模式。正则表达式广泛应用于字符串搜索、替换和解析。Java通过java.util.regex包提供了对正则表达式的支持,该包包含两…...

Python xlrd库:读excel表格
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…...

开发中遇到的一个bug
遇到的报错信息是这样的: java: Annotation processing is not supported for module cycles. Please ensure that all modules from cycle [hm-api,hm-common,hm-service] are excluded from annotation processing 翻译过来就是存在循环引用的情况,导…...
Java面试题:对比不同的垃圾收集器(如Serial、Parallel、CMS、G1)及其适用场景
Java虚拟机(JVM)提供了多种垃圾收集器,每种垃圾收集器在性能和适用场景上各有不同。以下是对几种常见垃圾收集器(Serial、Parallel、CMS、G1)的对比及其适用场景的详细介绍: 1. Serial 垃圾收集器 Serial…...

每日一题——冒泡排序
C语言——冒泡排序 冒泡排序练习 前言:CSDN的小伙伴们,大家好!今天我来给大家分享一种解题思想——冒泡排序。 冒泡排序 冒泡法的核心思想:两两相邻的元素进行比较 2.冒泡排序的算法描述如下。 (1)比较相邻的元素。如果第一 个比…...
javascript浏览器对象模型
BOM对象: BOM 是浏览器对象模型的简称。JavaScript 将整个浏览器窗口按照实现的功能不同拆分成若干个对象; 包含:window 对象、history 对象、location 对象和 document 对象等 window对象: 常用方法: 1.prompt();…...
C语言之链表以及单链表的实现
一:链表的引入 1:从数组的缺陷说起 (1)数组有两个缺陷。一个是数组中所有元素类型必须一致,第二是数组的元素个数必须事先指定并且一旦指定后不能更改 (2)如何解决数组的两个缺陷:数…...

AI在线免费视频工具2:视频配声音;图片说话hedra
1、视频配声音 https://deepmind.google/discover/blog/generating-audio-for-video/ https://www.videotosoundeffects.com/ (免费在线使用) 2、图片说话在线图片生成播报hedra hedra 上传音频与图片即可合成 https://www.hedra.com/ https://www.…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...

大数据学习栈记——Neo4j的安装与使用
本文介绍图数据库Neofj的安装与使用,操作系统:Ubuntu24.04,Neofj版本:2025.04.0。 Apt安装 Neofj可以进行官网安装:Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...
【杂谈】-递归进化:人工智能的自我改进与监管挑战
递归进化:人工智能的自我改进与监管挑战 文章目录 递归进化:人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管?3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...
基础测试工具使用经验
背景 vtune,perf, nsight system等基础测试工具,都是用过的,但是没有记录,都逐渐忘了。所以写这篇博客总结记录一下,只要以后发现新的用法,就记得来编辑补充一下 perf 比较基础的用法: 先改这…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...

Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级
在互联网的快速发展中,高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司,近期做出了一个重大技术决策:弃用长期使用的 Nginx,转而采用其内部开发…...
工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配
AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...

C++使用 new 来创建动态数组
问题: 不能使用变量定义数组大小 原因: 这是因为数组在内存中是连续存储的,编译器需要在编译阶段就确定数组的大小,以便正确地分配内存空间。如果允许使用变量来定义数组的大小,那么编译器就无法在编译时确定数组的大…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...