首頁 > 後端開發 > php教程 > 解決Yii框架參數化查詢中IN查詢只能查詢一個的問題

解決Yii框架參數化查詢中IN查詢只能查詢一個的問題

*文
發布: 2023-03-19 07:28:02
原創
1968 人瀏覽過

如何解決Yii框架參數化查詢中IN查詢只能查詢一個的問題?本文主要介紹了Yii框架參數化查詢中IN查詢只能查詢一個的解決方法,結合實例形式分析了Yii框架中IN查詢只能查一個的原因及FIND_IN_SET函數相關功能與使用技巧,需要的朋友可以參考下。希望對大家有幫助。

具體如下:

在yii框架中使用參數化進行IN查詢時,結果不如所願

1

2

3

4

5

6

$sql =<<<SQL

SELECT id FROM tb WHERE id IN(:ids)

SQL;

$db = GeneralService::getSlaveDB();

$result = $db->createCommand($sql)->query([&#39;:ids&#39; => &#39;1013,1015,1017&#39;])->readAll();

print_r($result);

登入後複製

1

2

3

4

5

6

7

Array

(

  [0] => Array

    (

      [id] => 1013

    )

)

登入後複製

於是翻了yii框架中相關源碼,發現採用的是pdo查詢,於是又查詢了pdo相關資料,知道了原因:不能讓佔位符取代一組值

1

SELECT id FROM tb WHERE userid IN ( ? );

登入後複製

既然知道了原因,那麼就找到替代的方法,FIND_IN_SET正好可以滿足

1

2

3

4

5

6

$sql =<<<SQL

SELECT id FROM tb WHERE FIND_IN_SET(id, :ids)

SQL;

$db = GeneralService::getSlaveDB();

$result = $db->createCommand($sql)->query([&#39;:ids&#39; => &#39;1013,1015,1017&#39;])->readAll();

print_r($result);

登入後複製

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

Array

(

  [0] => Array

    (

      [id] => 1013

    )

  [1] => Array

    (

      [id] => 1015

    )

  [2] => Array

    (

      [id] => 1017

    )

)

登入後複製

簡單科普下FIND_IN_SET函數

1

FIND_IN_SET(str,strlist)

登入後複製

假如字符串str在由N子鏈組成的字串清單strlist中,則傳回值的範圍在1 到N 之間。

一個字串清單就是一個由一些被 ‘,' 符號分開的子鏈所組成的字串。如果第一個參數是常數字串,而第二個是type SET列,則   FIND_IN_SET() 函數被最佳化,使用位元計算。

如果str不在strlist 或strlist 為空字串,則傳回值為 0 。如任意一個參數為NULL,則傳回值為 NULL。這個函數在第一個參數包含一個逗號(‘,')時將無法正常運作。

【ps】strlist中由逗號組成的字串,不能像平常習慣的那樣,逗號右邊加個空格,那是認不出來的。

相關推薦:

#詳情yii2之restful api授權驗證

############ ########詳解Yii2如何實作自訂獨立驗證器###################Yii2整合迅搜實作高效能中文分詞擷取####### ###

以上是解決Yii框架參數化查詢中IN查詢只能查詢一個的問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
圖書查詢為什麼查不了
來自於 1970-01-01 08:00:00
0
0
0
查詢分頁
來自於 1970-01-01 08:00:00
0
0
0
mongodb聚合怎麼查看查詢效能?
來自於 1970-01-01 08:00:00
0
0
0
關於資料庫查詢
來自於 1970-01-01 08:00:00
0
0
0
MongoDB無法查詢數據
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板