mysql中循環(huán)截取用戶信息并插入到目標表對應(yī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 INVOKER BEGIN DROP 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) -- 不存在分號的時候,返回0 while m_num >= 1 do begin set @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_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 ;
相關(guān)文章
mysql8.0及以上my.cnf設(shè)置lower_case_table_names=1無法啟動問題
這篇文章主要介紹了mysql8.0及以上my.cnf設(shè)置lower_case_table_names=1無法啟動問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11MySQL報錯?:Error?writing?file?‘/tmp/XXXX‘?(Errcode:?28?
這篇文章主要給大家介紹了MySQL報錯解決:Error?writing?file?‘/tmp/XXXX‘?(Errcode:?28?-?No?space?left?on?device),文中通過代碼示例和圖文介紹的非常詳細,需要的朋友可以參考下2023-10-10mysql利用mysqlbinlog命令恢復(fù)誤刪除數(shù)據(jù)的實現(xiàn)
這篇文章主要介紹了mysql利用mysqlbinlog命令恢復(fù)誤刪除數(shù)據(jù)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-03-03SUSE Linux下通過RPM方式卸載MySQL 5過程筆記
這篇文章主要介紹了SUSE Linux下通過RPM方式卸載MySQL 5過程筆記,本文針對使用rpm方式安裝的mysql,需要的朋友可以參考下2014-09-09