Yii2增刪改查之查詢 where參數詳細介紹
來源:易賢網 閱讀:1567 次 日期:2016-08-29 14:02:36
溫馨提示:易賢網小編為您整理了“Yii2增刪改查之查詢 where參數詳細介紹”,方便廣大網友查閱!

概述

由于官方手冊關于where的介紹比較少,所以想自己整理一下,以便大家的學習和自己回頭查詢。本篇文章會詳細介紹and、or、between、in、like在where方法中的使用方法和舉例。

and:

// 我們要查詢id大于1并且小于3的數據

$userInfo = User::find()->where(['and' , 'id > 1' , 'id < 3'])->all();

// 或者用以下方式,更為安全

$userInfo = User::find()->where(['and' , ['>' , 'id' , 1] , ['<' , 'id' , 3]])->all();

// 往往我們會處理比這更復雜的sql

// 假如我們要查詢name是王五 并且 id大于1或者id小于3的數據

$userInfo = User::find()->where(

['and' ,

['=' , 'name' , '王五'] ,

['or' ,

['=' , 'id' , 1] ,

['=' , 'id' , 3]

]

])->asArray()->all();

// 注:asArray()方法會將數據以數組的方式顯示

or:

// 我們要查詢id等于1或者id等于3的數據

$userInfo = User::find()->where(['or' , 'id = 1' , 'id = 3'])->all();

// 我們同樣可以使用以下方式

$userInfo = User::find()->where(['or' , ['=' , 'id' , 1] , ['=' , 'id' , 3]])->all();

// 假如我們要查詢id在4,8,9范圍內 或者 id在1,2,3范圍內呢?

$userInfo = User::find()->where(['or' , ['id' => [4,8,9]] , ['id' => [1,2,3]]])->all();

between:

// 我們要查詢id在1到10的范圍之內

$userInfo = User::find()->where(['between' , 'id' , 1 , 10])->all();

in:

// 我們要查詢id在1、2、3的范圍內

$userInfo = User::find()->where(['in' , 'id' , [1,2,3]])->all();

like:

// 我們要查詢name中包含“張”這個字符的數據

$userInfo = User::find()->where(['like' , 'name' , '張'])->all();

// 我們假如要通配name中包含“張”這個字符,而且還得包含“三”這個字符

$userInfo = User::find()->where(['like' , 'name' , ['張' , '三']])->all();

// 我們假如只需要通配左邊即可

$userInfo = User::find()->where(['like' , 'name' , '%三' , false])->all();

// 所以,右邊也是同樣

以上所述是小編給大家介紹的Yii2增刪改查之查詢 where參數詳細介紹的相關知識,希望對大家有所幫助

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看