mysql用存储过程循环截取用户信息并插入到目标表对应

sunshine技术博客 sunshine技术博客

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;……”

代码如下:

  1. --使用存储过程
  2. delimiter$$
  3. use`log_pdk`$$
  4. dropprocedureifexists`game_c`$$
  5. createprocedure`game_c`(ini_player_detailvarchar(500))
  6. SQLSECURITYINVOKER
  7. BEGIN
  8. DROPTABLEIFEXISTS`temp_list`;
  9. --创建临时表,将截取的数据先插入到临时表
  10. CREATETEMPORARYTABLE`temp_list`(
  11. `uid`INT(10)UNSIGNEDNOTNULL,
  12. `score1`INT(10)UNSIGNEDNOTNULL,
  13. `score2`INT(10)UNSIGNEDNOTNULL,
  14. `seat_id`TINYINT(3)UNSIGNEDNOTNULL
  15. );
  16. --declarestrvarchar(500);--用来拼接sql动态语句
  17. declarem_detailvarchar(500);
  18. declarem_numtinyint;
  19. --当传入的用户信息字符串中含有分号';',进行截取
  20. setm_num=position(';'instr)--不存在分号的时候,返回0
  21. whilem_num>=1do
  22. begin
  23. set@str='insertintotemp_listvalues('+substring(m_detail,1,m_num-1)+')'--截取第一个用户的信息(第一个分号前面的字符),插入到临时表
  24. preparestatement1from@str;
  25. executestatement1;
  26. deallocatepreparestatement1;
  27. setm_detail=substring(m_detail,m_num+1);--定义除去第一个用户和分号那部分的字符串
  28. setsetm_num=position(';'instr);
  29. endwhile;--phpfensi.com
  30. --从临时表抽出所有字段,添加时间字段,插入到表game_list
  31. INSERTINTO`game_list`(`uid`,`score1`,`score2`,`seat_id`,`last_update`)
  32. SELECT`uid`,`score1`,`score2`,`seat_id`,current_date()
  33. FROM`temp_list`;
  34. end$$
  35. delimiter;

相关广告
  • mysql用存储过程循环截取用户信息并插入到目标表对应 mysql用存储过程循环截取用户信息并插入到目标表对应 mysql用存储过程循环截取用户信息并插入到目标表对应
相关阅读

mysql用存储过程循环截取用户信息并插入到目标表对应

2019/10/10 17:32:21 | 谷歌SEO算法 | 谷歌CEO