国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql用存儲過程重復截取用戶信息并插入到目標表對應

2024-07-24 12:35:10
字體:
來源:轉載
供稿:網友
  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;。
 

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 龙门县| 眉山市| 尼木县| 肇州县| 惠安县| 湘潭县| 温州市| 双鸭山市| 昔阳县| 泰来县| 诸城市| 方正县| 瓦房店市| 浏阳市| 孝昌县| 大方县| 云龙县| 来宾市| 洪湖市| 三原县| 武定县| 当阳市| 加查县| 交城县| 田阳县| 洱源县| 黄龙县| 仁布县| 营口市| 宜州市| 中牟县| 会理县| 贡山| 泰兴市| 杭锦后旗| 北川| 贵溪市| 前郭尔| 崇左市| 南澳县| 垣曲县|