MySQL 存儲(chǔ)過程傳參數(shù)實(shí)現(xiàn)where id in(1,2,3,...)示例
更新時(shí)間:2013年10月30日 16:46:25 作者:
一個(gè)MySQL 存儲(chǔ)過程傳參數(shù)的問題想實(shí)現(xiàn)例如篩選條件為:where id in(1,2,3,...),下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下
正常寫法:
select * from table_name t where t.field1 in (1,2,3,4,...);
當(dāng)在寫存儲(chǔ)過程in里面的列表用個(gè)傳入?yún)?shù)代入的時(shí)候,就需要用到如下方式:
主要用到find_in_set函數(shù)
select * from table_name t where find_in_set(t.field1,'1,2,3,4');
當(dāng)然還可以比較笨實(shí)的方法,就是組裝字符串,然后執(zhí)行:
DROP PROCEDURE IF EXISTS photography.Proc_Test;
CREATE PROCEDURE photography.`Proc_Test`(param1 varchar(1000))
BEGIN
set @id = param1;
set @sel = 'select * from access_record t where t.ID in (';
set @sel_2 = ')';
set @sentence = concat(@sel,@id,@sel_2); -- 連接字符串生成要執(zhí)行的SQL語句
prepare stmt from @sentence; -- 預(yù)編釋一下。 “stmt”預(yù)編釋變量的名稱,
execute stmt; -- 執(zhí)行SQL語句
deallocate prepare stmt; -- 釋放資源
END;
復(fù)制代碼 代碼如下:
select * from table_name t where t.field1 in (1,2,3,4,...);
當(dāng)在寫存儲(chǔ)過程in里面的列表用個(gè)傳入?yún)?shù)代入的時(shí)候,就需要用到如下方式:
主要用到find_in_set函數(shù)
復(fù)制代碼 代碼如下:
select * from table_name t where find_in_set(t.field1,'1,2,3,4');
當(dāng)然還可以比較笨實(shí)的方法,就是組裝字符串,然后執(zhí)行:
復(fù)制代碼 代碼如下:
DROP PROCEDURE IF EXISTS photography.Proc_Test;
CREATE PROCEDURE photography.`Proc_Test`(param1 varchar(1000))
BEGIN
set @id = param1;
set @sel = 'select * from access_record t where t.ID in (';
set @sel_2 = ')';
set @sentence = concat(@sel,@id,@sel_2); -- 連接字符串生成要執(zhí)行的SQL語句
prepare stmt from @sentence; -- 預(yù)編釋一下。 “stmt”預(yù)編釋變量的名稱,
execute stmt; -- 執(zhí)行SQL語句
deallocate prepare stmt; -- 釋放資源
END;
相關(guān)文章
mysql中使用sql命令將時(shí)間戳解析成datetime類型存入
這篇文章主要介紹了mysql中使用sql命令將時(shí)間戳解析成datetime類型存入,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
MySQL中關(guān)于臨時(shí)表的一些基本使用方法
這篇文章主要介紹了MySQL中關(guān)于臨時(shí)表的一些基本使用方法,是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-05-05
mysql條件查詢and or使用方法及優(yōu)先級實(shí)例分析
這篇文章主要介紹了mysql條件查詢and or使用方法及優(yōu)先級,結(jié)合實(shí)例形式分析了mysql條件查詢and or基本功能、用法及優(yōu)先級相關(guān)操作技巧,需要的朋友可以參考下2020-04-04
一文徹底搞懂MySQL?TimeStamp時(shí)區(qū)問題
MySQL的timestamp類型默認(rèn)使用的是服務(wù)器的時(shí)區(qū)來存儲(chǔ)時(shí)間值,這意味著如果服務(wù)器的時(shí)區(qū)發(fā)生了變化,那么存儲(chǔ)的timestamp值也會(huì)發(fā)生變化,下面這篇文章主要給大家介紹了關(guān)于如何通過一文徹底搞懂MySQL?TimeStamp時(shí)區(qū)問題的相關(guān)資料,需要的朋友可以參考下2024-01-01
MySQL UPDATE 語句的非標(biāo)準(zhǔn)實(shí)現(xiàn)代碼
這篇文章主要介紹了MySQL UPDATE 語句的非標(biāo)準(zhǔn)實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04

