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;

相关推荐
呼拉拉呼拉7 分钟前
Redis故障转移
数据库·redis·缓存·高可用架构
什么都想学的阿超10 分钟前
【Redis系列 04】Redis高可用架构实战:主从复制与哨兵模式从零到生产
数据库·redis·架构
pp-周子晗(努力赶上课程进度版)31 分钟前
【MySQL】视图、用户管理、MySQL使用C\C++连接
数据库·mysql
斯特凡今天也很帅40 分钟前
clickhouse常用语句汇总——持续更新中
数据库·sql·clickhouse
超级小忍2 小时前
如何配置 MySQL 允许远程连接
数据库·mysql·adb
吹牛不交税2 小时前
sqlsugar WhereIF条件的大于等于和等于查出来的坑
数据库·mysql
Java水解2 小时前
MySQL DQL全面解析:从入门到精通
后端·mysql
hshpy3 小时前
setting up Activiti BPMN Workflow Engine with Spring Boot
数据库·spring boot·后端
文牧之4 小时前
Oracle 审计参数:AUDIT_TRAIL 和 AUDIT_SYS_OPERATIONS
运维·数据库·oracle