欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2014年08月07日 15:35:21   投稿:whsnow  
將各個(gè)用戶對(duì)應(yīng)的屬性插入到目標(biāo)表對(duì)應(yīng)的字段中,last_update為數(shù)據(jù)更新日期

操作環(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)(;)隔開(kāi);
操作目的:將各個(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)隔開(kāi),每個(gè)用戶的信息多個(gè),比如
“用戶id,score,desk,seat;
用戶id,score,desk,seat;……”

-- 使用存儲(chǔ)過(guò)程
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í)表,將截取的數(shù)據(jù)先插入到臨時(shí)表
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);-- 用來(lái)拼接sql動(dòng)態(tài)語(yǔ)句
declare m_detail varchar(500);
declare m_num tinyint;

-- 當(dāng)傳入的用戶信息字符串中含有分號(hào)';',進(jìn)行截取
set m_num = position(';' in str) -- 不存在分號(hào)的時(shí)候,返回0
while m_num >= 1 do
begin
set @str = 'insert into temp_list values (' + substring(m_detail,1,m_num-1)+')' -- 截取第一個(gè)用戶的信息(第一個(gè)分號(hào)前面的字符),插入到臨時(shí)表
prepare statement1 from @str;
execute statement1;
deallocate prepare statement1;
set m_detail = substring(m_detail,m_num+1); -- 定義除去第一個(gè)用戶和分號(hào)那部分的字符串
set set m_num = position(';' in str);
end while;

-- 從臨時(shí)表抽出所有字段,添加時(shí)間字段,插入到表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)文章

  • 詳解MySQL多版本并發(fā)控制機(jī)制(MVCC)源碼

    詳解MySQL多版本并發(fā)控制機(jī)制(MVCC)源碼

    MVCC,即多版本并發(fā)控制(Multi-Version Concurrency Control)指的是,通過(guò)版本鏈維護(hù)一個(gè)數(shù)據(jù)的多個(gè)版本,使得讀寫(xiě)操作沒(méi)有沖突,可保證不同事務(wù)讀寫(xiě)、寫(xiě)讀操作并發(fā)執(zhí)行,提高系統(tǒng)性能
    2021-06-06
  • Mysql中基本語(yǔ)句優(yōu)化的十個(gè)原則小結(jié)

    Mysql中基本語(yǔ)句優(yōu)化的十個(gè)原則小結(jié)

    這篇文章主要給大家總結(jié)介紹了Mysql中基本語(yǔ)句優(yōu)化的十個(gè)原則,通過(guò)學(xué)習(xí)與記住它們,在構(gòu)造sql時(shí)可以養(yǎng)成良好的習(xí)慣,文中介紹的相對(duì)比較詳細(xì)與簡(jiǎn)單明了,需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2017-06-06
  • 為MySQL創(chuàng)建高性能索引

    為MySQL創(chuàng)建高性能索引

    這篇文章介紹了為MySQL創(chuàng)建高性能索引的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • mysql8.0及以上my.cnf設(shè)置lower_case_table_names=1無(wú)法啟動(dòng)問(wèn)題

    mysql8.0及以上my.cnf設(shè)置lower_case_table_names=1無(wú)法啟動(dòng)問(wèn)題

    這篇文章主要介紹了mysql8.0及以上my.cnf設(shè)置lower_case_table_names=1無(wú)法啟動(dòng)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • MySQL報(bào)錯(cuò)?:Error?writing?file?‘/tmp/XXXX‘?(Errcode:?28?-?No?space?left?on?device)的解決方法

    MySQL報(bào)錯(cuò)?:Error?writing?file?‘/tmp/XXXX‘?(Errcode:?28?

    這篇文章主要給大家介紹了MySQL報(bào)錯(cuò)解決:Error?writing?file?‘/tmp/XXXX‘?(Errcode:?28?-?No?space?left?on?device),文中通過(guò)代碼示例和圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • mysql利用mysqlbinlog命令恢復(fù)誤刪除數(shù)據(jù)的實(shí)現(xiàn)

    mysql利用mysqlbinlog命令恢復(fù)誤刪除數(shù)據(jù)的實(shí)現(xiàn)

    這篇文章主要介紹了mysql利用mysqlbinlog命令恢復(fù)誤刪除數(shù)據(jù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MYSQL8.0.13免安裝版配置教程實(shí)例詳解

    MYSQL8.0.13免安裝版配置教程實(shí)例詳解

    這篇文章主要介紹了MYSQL8.0.13免安裝版 配置教程,本文是以8.0為例,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2018-12-12
  • MySQL中any、some和all的用法實(shí)例

    MySQL中any、some和all的用法實(shí)例

    最近一直在練習(xí)MYSQL的多表查詢,基本上每個(gè)查詢語(yǔ)句我都會(huì)寫(xiě)至少兩次,下面這篇文章主要給大家介紹了關(guān)于MySQL中any、some和all用法的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • mysql8.0 JSON_CONTAINS的使用說(shuō)明

    mysql8.0 JSON_CONTAINS的使用說(shuō)明

    這篇文章主要介紹了mysql8.0 JSON_CONTAINS的使用說(shuō)明,具有很好的參考價(jià)值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • SUSE Linux下通過(guò)RPM方式卸載MySQL 5過(guò)程筆記

    SUSE Linux下通過(guò)RPM方式卸載MySQL 5過(guò)程筆記

    這篇文章主要介紹了SUSE Linux下通過(guò)RPM方式卸載MySQL 5過(guò)程筆記,本文針對(duì)使用rpm方式安裝的mysql,需要的朋友可以參考下
    2014-09-09

最新評(píng)論