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

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

mysql中循環(huán)截取用戶信息并插入到目標表對應(yīng)的字段中

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

操作環(huán)境:有表game_list,字段:uid,score1,score2,seat_id,last_update;
傳入?yún)?shù)為i_player_detail ,傳入的值為多個用戶的id、之前分數(shù)、之后分數(shù)、座位號,每個用戶的數(shù)據(jù)用分號(;)隔開;
操作目的:將各個用戶對應(yīng)的屬性插入到目標表對應(yīng)的字段中,last_update為數(shù)據(jù)更新日期;
傳入?yún)?shù)i_player_detail ,里面存放多個用戶的信息,每個用戶的一組數(shù)據(jù)用分號隔開,每個用戶的信息多個,比如
“用戶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 INVOKERBEGINDROP TABLE IF EXISTS `temp_list`;--創(chuàng)建臨時表,將截取的數(shù)據(jù)先插入到臨時表CREATE TEMPORARY TABLE `temp_list`(`uid` INT(10) UNSIGNED NOT NULL,`score1` INT(10) UNSIGNED NOT NULL,`score2` INT(10) UNSIGNED NOT NULL,`seat_id` TINYINT(3) UNSIGNED NOT NULL);-- declare str varchar(500);-- 用來拼接sql動態(tài)語句declare m_detail varchar(500);declare m_num tinyint;-- 當傳入的用戶信息字符串中含有分號';',進行截取set m_num = position(';' in str) -- 不存在分號的時候,返回0while m_num >= 1 dobeginset @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一個用戶的信息(第一個分號前面的字符),插入到臨時表prepare statement1 from @str;execute statement1;deallocate prepare statement1;set m_detail = substring(m_detail,m_num+1); -- 定義除去第一個用戶和分號那部分的字符串set set m_num = position(';' in str);end while;-- 從臨時表抽出所有字段,添加時間字段,插入到表game_listINSERT INTO `game_list`(`uid`,`score1`,`score2`,`seat_id`, `last_update`)SELECT `uid`, `score1`, `score2`, `seat_id`, current_date() FROM `temp_list`;end$$delimiter ;

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 淳安县| 新闻| 喀喇| 大名县| 永新县| 奉新县| 若羌县| 商南县| 板桥市| 吴忠市| 平湖市| 扎囊县| 治县。| 额尔古纳市| 桓台县| 老河口市| 正镶白旗| 苗栗市| 永寿县| 呼和浩特市| 南宁市| 钟山县| 黄冈市| 平塘县| 阳东县| 木兰县| 万盛区| 宁阳县| 贵南县| 祁阳县| 天全县| 吉林市| 揭西县| 江门市| 贵德县| 临颍县| 黑水县| 新乡市| 古交市| 清涧县| 上栗县|