MySQL中存储过程(procedure)的使用

概念

存储过程:在数据库中预先定义好一组SQL语句,可以被程序反复调用。

优点:

  • 存储过程将一组复杂的SQL语句组成一个原子操作,保证数据一致性。
  • 批处理操作,保证操作高效性。
  • 通过存储过程可以限制用户对数据库中敏感数据访问。提高系统安全性。

示例1

1、MySQL创建存储过程。

sql 复制代码
DELIMITER $$
CREATE PROCEDURE GetCustomerDetails(IN haha INT)
BEGIN
    SELECT * FROM customer WHERE id = haha;
END $$
DELIMITER ;

2、MySQL调用存储过程。

sql 复制代码
call GetCustomerDetails(16);

3、Java调用存储过程。

sql 复制代码
<mapper namespace="com.example.MyMapper">
    <select id="getCustomerDetails" statementType="CALLABLE">
        {call GetCustomerDetails(#{customerId, mode=IN, jdbcType=INTEGER})}
    </select>

    <update id="updateCustomerDetails" statementType="CALLABLE">
        {call UpdateCustomerDetails(
            #{customerId, mode=IN, jdbcType=INTEGER},
            #{firstName, mode=IN, jdbcType=VARCHAR},
            #{lastName, mode=IN, jdbcType=VARCHAR}
        )}
    </update>
</mapper>

示例2

用存储过程来实现往一个表里持续插入数据的操作。

sql 复制代码
-- 创建存储过程
DELIMITER $$ #重新定义结束符
CREATE PROCEDURE person_procedure ( IN minNum INT, IN maxNum INT ) 
BEGIN
	DECLARE i INT DEFAULT minNum; #设置i初始值为minNum
	WHILE i <= maxNum DO
		INSERT INTO person (id,`name`,age,address) VALUES (i,concat( 'cve-', i, '' ),i,concat( '地址-', i, '' ));
		SET i = i + 1;
	END WHILE;
	SELECT CONCAT(i, ' rows inserted.') AS Result; #打印一个输出
END $$
DELIMITER; #重新定义结束符
-- MySQL调用存储过程
call person_procedure(1,10);
相关推荐
绝知此事9 小时前
【算法突围 02】树形结构与数据库索引:树形结构与数据库索引:从 BST 到 B+ 树的演化与 MySQL 优化
数据库·mysql·算法·面试·b+树
muddjsv12 小时前
SQL 最常用技能详解与实战示例
数据库·sql·mysql
ᰔᩚ. 一怀明月ꦿ13 小时前
MySQL 学习目标
学习·mysql·adb
他们叫我阿冠17 小时前
Day4学习--MySQL高级
数据库·学习·mysql
罗超驿18 小时前
20.MySQL事务隔离级别示例详解(脏读、不可重复读、幻读)
java·数据库·mysql·面试
独泪了无痕19 小时前
MySQL中 JSON 数据类型使用指南
mysql
我是一颗柠檬19 小时前
【MySQL全面教学】MySQL基础与环境搭建Day1(2026年)
数据库·后端·sql·mysql·database
我是一颗柠檬19 小时前
【MySQL全面教学】MySQL数据类型详解Day2(2026年)
数据库·后端·sql·mysql·database
小江的记录本20 小时前
【Java并发编程】锁机制:volatile:JMM内存模型、可见性/禁止指令重排、内存屏障、单例模式中的应用(附《思维导图》+《面试高频考点清单》)
java·后端·python·mysql·单例模式·面试·职场和发展
身如柳絮随风扬20 小时前
CentOS 7 搭建 MySQL 主从复制集群:从零到生产级高可用
linux·mysql·centos