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

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

mysql用存儲(chǔ)過程循環(huán)截取用戶信息并插入到目標(biāo)表對(duì)應(yīng)

2024-07-24 12:39:47
字體:
供稿:網(wǎng)友

mysql用存儲(chǔ)過程循環(huán)截取用戶信息并插入到目標(biāo)表對(duì)應(yīng)的字段實(shí)例

以下實(shí)實(shí)例實(shí)現(xiàn)的功能是mysql創(chuàng)建一個(gè)存儲(chǔ)過程,然后循環(huán)環(huán)截取用戶信息并插入到目標(biāo)表對(duì)應(yīng)的字段,這個(gè)功能對(duì)網(wǎng)站改版用處比較大.

操作環(huán)境:有表game_list,字段:uid,score1,score2,seat_id,last_update;

傳入?yún)?shù)為i_player_detail,傳入的值為多個(gè)用戶的id、之前分?jǐn)?shù)、之后分?jǐn)?shù)、座位號(hào),每個(gè)用戶的數(shù)據(jù)用分號(hào)(;)隔開;

操作目的:將各個(gè)用戶對(duì)應(yīng)的屬性插入到目標(biāo)表對(duì)應(yīng)的字段中,last_update為數(shù)據(jù)更新日期;

傳入?yún)?shù)i_player_detail,里面存放多個(gè)用戶的信息,每個(gè)用戶的一組數(shù)據(jù)用分號(hào)隔開,每個(gè)用戶的信息多個(gè),比如.

“用戶id,score,desk,seat;

用戶id,score,desk,seat;……”

代碼如下:

  1. -- 使用存儲(chǔ)過程 
  2. delimiter $$ 
  3.  
  4. use `log_pdk`$$ 
  5.  
  6. drop procedure if exists `game_c`$$ 
  7.  
  8. create procedure `game_c` (in i_player_detail varchar(500)) 
  9. SQL SECURITY INVOKER 
  10. BEGIN 
  11.  
  12. DROP TABLE IF EXISTS `temp_list`; 
  13.  
  14. --創(chuàng)建臨時(shí)表,將截取的數(shù)據(jù)先插入到臨時(shí)表 
  15. CREATE TEMPORARY TABLE `temp_list`( 
  16. `uid` INT(10) UNSIGNED NOT NULL
  17. `score1` INT(10) UNSIGNED NOT NULL
  18. `score2` INT(10) UNSIGNED NOT NULL
  19. `seat_id` TINYINT(3) UNSIGNED NOT NULL 
  20. ); 
  21.  
  22. -- declare str varchar(500);-- 用來拼接sql動(dòng)態(tài)語句 
  23. declare m_detail varchar(500); 
  24. declare m_num tinyint; 
  25.  
  26. -- 當(dāng)傳入的用戶信息字符串中含有分號(hào)';',進(jìn)行截取 
  27. set m_num = position(';' in str) -- 不存在分號(hào)的時(shí)候,返回0 
  28. while m_num >= 1 do 
  29. begin 
  30. set @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一個(gè)用戶的信息(第一個(gè)分號(hào)前面的字符),插入到臨時(shí)表 
  31. prepare statement1 from @str; 
  32. execute statement1; 
  33. deallocate prepare statement1; 
  34. set m_detail = substring(m_detail,m_num+1); -- 定義除去第一個(gè)用戶和分號(hào)那部分的字符串 
  35. set set m_num = position(';' in str); 
  36. end while; --Vevb.com 
  37.  
  38. -- 從臨時(shí)表抽出所有字段,添加時(shí)間字段,插入到表game_list 
  39. INSERT INTO `game_list`(`uid`,`score1`,`score2`,`seat_id`, `last_update`) 
  40. SELECT `uid`, `score1`, `score2`, `seat_id`, current_date()  
  41. FROM `temp_list`; 
  42. end$$ 
  43. delimiter;

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 全州县| 广宗县| 武山县| 米易县| 磐石市| 黄山市| 宁陕县| 新巴尔虎左旗| 上林县| 景东| 香港| 塔城市| 晋城| 张家川| 于都县| 瓦房店市| 桂林市| 三明市| 永新县| 尖扎县| 龙游县| 汉阴县| 乐亭县| 广安市| 海原县| 万山特区| 九台市| 桓台县| 云林县| 闽清县| 赤城县| 台湾省| 博罗县| 潮安县| 九江县| 呼和浩特市| 南岸区| 和平县| 抚州市| 五原县| 敦煌市|