数据库教程: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;……”

--使用存储过程 delimiter$$ use`log_pdk`$$ dropprocedureifexists`game_c`$$ createprocedure`game_c`(ini_player_detailvarchar(500)) SQLSECURITYINVOKER BEGIN DROPTABLEIFEXISTS`temp_list`; --创建临时表,将截取的数据先插入到临时表 CREATETEMPORARYTABLE`temp_list`( `uid`INT(10)UNSIGNEDNOTNULL, `score1`INT(10)UNSIGNEDNOTNULL, `score2`INT(10)UNSIGNEDNOTNULL, `seat_id`TINYINT(3)UNSIGNEDNOTNULL ); --declarestrvarchar(500);--用来拼接sql动态语句 declarem_detailvarchar(500); declarem_numtinyint; --当传入的用户信息字符串中含有分号';',进行截取 setm_num=position(';'instr)--不存在分号的时候,返回0 whilem_num>=1do begin set@str='insertintotemp_listvalues('+substring(m_detail,1,m_num-1)+')'--截取第一个用户的信息(第一个分号前面的字符),插入到临时表 preparestatement1from@str; executestatement1; deallocatepreparestatement1; setm_detail=substring(m_detail,m_num+1);--定义除去第一个用户和分号那部分的字符串 setsetm_num=position(';'instr); endwhile; --从临时表抽出所有字段,添加时间字段,插入到表game_list INSERTINTO`game_list`(`uid`,`score1`,`score2`,`seat_id`,`last_update`) SELECT`uid`,`score1`,`score2`,`seat_id`,current_date() FROM`temp_list`; end$$ delimiter;

标签: mysql 字段 循环 sq

mysql获得60天前unix时间思路及代码

mysql 中如何取得汉字字段的各汉字首字母

上述就是数据库技术:mysql中循环截取用户信息并插入到目标表对应的字段中分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/911236.html

(0)
上一篇 2021年10月25日
下一篇 2021年10月25日

精彩推荐