设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 创业者 数据 手机
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2022-06-28 14:26 所属栏目:115 来源:互联网
导读:mysql用存储过程循环截取用户信息并插入到目标表对应的字段实例 以下实实例实现的功能是mysql创建一个存储过程,然后循环环截取用户信息并插入到目标表对应的字段,这个功能对网站改版用处比较大. 操作环境:有表game_list,字段:uid,score1,score2,seat_id,last
  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;……”
 
  代码如下:
 
  -- 使用存储过程
  delimiter $$
  
  use `log_pdk`$$
  
  drop procedure if exists `game_c`$$
  
  create procedure `game_c` (in i_player_detail varchar(500))
  SQL SECURITY INVOKER
  BEGIN
  
  DROP TABLE IF EXISTS `temp_list`;
  
  --创建临时表,将截取的数据先插入到临时表
  CREATE TEMPORARY TABLE `temp_list`(

  -- 当传入的用户信息字符串中含有分号';',进行截取
  set m_num = position(';' in str) -- 不存在分号的时候,返回0
  while m_num >= 1 do
  begin
  set @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一个用户的信息(第一个分号前面的字符),插入到临时表
  
  -- 从临时表抽出所有字段,添加时间字段,插入到表game_list
  INSERT INTO `game_list`(`uid`,`score1`,`score2`,`seat_id`, `last_update`)
  SELECT `uid`, `score1`, `score2`, `seat_id`, current_date()  
  FROM `temp_list`;
  end$$
  delimiter;。
 

(编辑:ASP站长网)

    网友评论
    推荐文章
      热点阅读