为了账号安全,请及时绑定邮箱和手机立即绑定

mysql中循环截取用户信息并插入到目标表对应的字段中

标签:
MySQL

操作环境:有表game_list,字段:uid,score1,score2,seat_id,last_update;
传入参数为i_player_detail ,传入的值为多个用户的id、之前分数、之后分数、座位号,每个用户的数据用分号(;)隔开;
操作目的:将各个用户对应的属性插入到目标表对应的字段中,last_update为数据更新日期;
传入参数i_player_detail ,里面存放多个用户的信息,每个用户的一组数据用分号隔开,每个用户的信息多个,比如
“用户id,score,desk,seat;
用户id,score,desk,seat;……”

?

12345678910111213141516171819202122232425262728293031323334353637383940414243-- 使用存储过程delimiter $$ use `log_pdk`$$ drop procedure if exists `game_c`$$ create procedure `game_c` (in i_player_detail varchar(500))SQL SECURITY INVOKERBEGIN DROP TABLE IF EXISTS `temp_list`; --创建临时表,将截取的数据先插入到临时表CREATE TEMPORARY TABLE `temp_list`(`uid` INT(10) UNSIGNED NOT NULL,`score1` INT(10) UNSIGNED NOT NULL,`score2` INT(10) UNSIGNED NOT NULL,`seat_id` TINYINT(3) UNSIGNED NOT NULL); -- declare str varchar(500);-- 用来拼接sql动态语句declare m_detail varchar(500);declare m_num tinyint; -- 当传入的用户信息字符串中含有分号';',进行截取set m_num = position(';' in str) -- 不存在分号的时候,返回0while m_num >= 1 dobeginset @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一个用户的信息(第一个分号前面的字符),插入到临时表prepare statement1 from @str;execute statement1;deallocate prepare statement1;set m_detail = substring(m_detail,m_num+1); -- 定义除去第一个用户和分号那部分的字符串set set m_num = position(';' in str);end while; -- 从临时表抽出所有字段,添加时间字段,插入到表game_listINSERT INTO `game_list`(`uid`,`score1`,`score2`,`seat_id`, `last_update`)SELECT `uid`, `score1`, `score2`, `seat_id`, current_date() FROM `temp_list`;end$$delimiter ;


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消