Mysql存储过程:字符串拆分方法、游标的使用、字符串拼成sql语句

一:字符串拆分方法 (类似java中split()与PaAdmin库中的split_part()函数)

CREATE DEFINER=`root`@`%` PROCEDURE `p_test`(IN `pnames` varchar(50))

BEGIN

-- pnames = 'a,b,c,d,e,f'

DECLARE _z_end int DEFAULT 0;

DECLARE _z_num int DEFAULT -1;

DECLARE _z_str varchar(50);

DECLARE _name varchar(50);

-- 创建临时表

DROP TABLE IF EXISTS p_test_msg;

create TEMPORARY table p_test_msg(

code varchar(50),

msg varchar(50)

);

set _z_str := SUBSTRING_INDEX(pnames,',',_z_num);

set _z_num = -1 + _z_num;

set _name:= SUBSTRING_INDEX(pnames,',',1) ;

while(_z_end <> -1) do

-- 插入临时表

insert into p_test_msg(code,msg) values(_z_num,_name);

set _z_str := SUBSTRING_INDEX(pnames,',',_z_num);

set _z_num = -1 + _z_num;

if(_z_str = pnames) then

set _z_end := -1;

end if;

set _name:= SUBSTRING_INDEX(_z_str,',',1) ;

end while;

SELECT * FROM p_test_msg;

END

二:存储过程中游标的使用

CREATE DEFINER=`root`@`%` PROCEDURE `p_demo`()

BEGIN

DECLARE name VARCHAR(32);

DECLARE phone VARCHAR(32);

DECLARE password VARCHAR(32);

-- 游标

DECLARE s int DEFAULT 0;

DECLARE temp CURSOR FOR SELECT a.user_name,a.user_tel,a.login_pwd from t_pm_user a ;

DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET s = 1;

-- 创建临时表

DROP TABLE IF EXISTS p_demo_msg;

create TEMPORARY table p_demo_msg(

code varchar(50),

msg varchar(50)

);

OPEN temp;

FETCH temp into name,phone,password;

while s<>1 do

-- 插入临时表

insert into p_demo_msg(code,msg) values(name,phone);

FETCH temp into name,phone,password;

END WHILE;

CLOSE temp;

SELECT * FROM p_demo_msg;

END

三:存储过程中执行用字符串拼成的sql语句

DROP PROCEDURE IF EXISTS test_prepareStam;

CREATE PROCEDURE test_prepareStam(IN id int)

BEGIN

TRUNCATE TABLE test_table;

/*

-- 直接拼sql 然后prepare EXECUTE

set @exeSql=concat("INSERT INTO test_table (id, val, uv, visitor_val, visitor_uv)VALUES (",id);

set @exeSql=concat(@exeSql,", 3,4,6,7)");

-- select @exeSql;

prepare stmt from @exeSql;

EXECUTE stmt;

deallocate prepare stmt;

*/

/*

-- 直接拼sql+? 然后prepare EXECUTE+using

set @_id=id;

set @exeSql=concat("INSERT INTO test_table (id, val, uv, visitor_val, visitor_uv)VALUES (?, 3,4,6,7)");

prepare stmt from @exeSql;

EXECUTE stmt using @_id; -- 多个用逗号隔开

deallocate prepare stmt;

*/

-- *********存储过程执行用字符串拼成的sql语句 *********

set @exeSql = ' INSERT INTO test_table (id, val, uv, visitor_val, visitor_uv)VALUES (111, 3,4,6,7) '; -- 注意很重要,将连成成的字符串赋值给一个变量(可以之前没有定义,但要以@开头)

prepare stmt from @exeSql; -- 预处理需要执行的动态SQL,其中stmt是一个变量

EXECUTE stmt; -- 执行SQL语句

deallocate prepare stmt; -- 释放掉预处理段

select * from test_table;

END;

相关推荐
数据组小组3 小时前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
爱可生开源社区5 小时前
MiniMax M2.5 的 SQL 能力令人惊艳!
sql·llm
用户8307196840828 小时前
MySQL 查询优化 30 条封神技巧:用好索引,少耗资源,查询快到飞起
mysql
Nyarlathotep01139 小时前
事务隔离级别
sql·mysql
悟空聊架构9 小时前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL9 小时前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
Nyarlathotep011312 小时前
SQL的事务控制
sql·mysql
进击的丸子12 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
用户861782773651813 小时前
MySQL 8.0从库宕机排查实录:中继日志膨胀引发的连锁故障复盘
mysql
NineData1 天前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析