首頁  >  文章  >  後端開發  >  Yii查詢中IN查詢只能查詢一個的方法

Yii查詢中IN查詢只能查詢一個的方法

巴扎黑
巴扎黑原創
2017-08-13 14:32:582761瀏覽

這篇文章主要介紹了Yii框架參數化查詢中IN查詢只能查詢一個的解決方法,結合實例形式分析了Yii框架中IN查詢只能查一個的原因及FIND_IN_SET函數相關功能與使用技巧,需要的朋友可以參考下

本文實例講述了Yii框架參數化查詢中IN查詢只能查詢一個的解決方法。分享給大家供大家參考,具體如下:

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


$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);


Array
(
  [0] => Array
    (
      [id] => 1013
    )
)

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


SELECT id FROM tb WHERE userid IN ( ? );

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


$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);


#
Array
(
  [0] => Array
    (
      [id] => 1013
    )
  [1] => Array
    (
      [id] => 1015
    )
  [2] => Array
    (
      [id] => 1017
    )
)

簡單科普下FIND_IN_SET函數


FIND_IN_SET(str,strlist)

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

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

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

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

#

以上是Yii查詢中IN查詢只能查詢一個的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn