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;

相关推荐
上山的月10 分钟前
MySQL -函数和约束
数据库·mysql
zhcf13 分钟前
【MySQL】十三,关于MySQL的全文索引
数据库·mysql
丁总学Java22 分钟前
要查询 `user` 表中 `we_chat_open_id` 列不为空的用户数量
数据库·mysql
抓哇能手22 分钟前
数据库系统概论
数据库·人工智能·sql·mysql·计算机
littlegirll23 分钟前
一个从oracle使用spool导出数据到kadb的脚本
数据库·oracle
geovindu25 分钟前
CSharp: Oracle Stored Procedure query table
数据库·oracle·c#·.net
油丶酸萝卜别吃38 分钟前
MyBatis中XML文件的模板
xml·数据库·mybatis
三天不学习40 分钟前
【Select 语法全解密】.NET开源ORM框架 SqlSugar 系列
数据库·.net·orm·微软技术·sqlsugar
CC呢1 小时前
基于单片机的智能婴儿床监护系统多功能婴儿床摇篮系统
数据库·mongodb
林的快手2 小时前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode