yii2使用AR類進行增刪改查操作
阿新 • • 發佈:2019-02-05
由於官方手冊關於where的介紹比較少,所以想自己整理一下,以便大家的學習和自己回頭查詢。本篇文章會詳細介紹and、or、between、in、like在where方法中的使用方法和舉例。
and
// 我們要查詢id大於1並且小於3的資料
$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的範圍之內
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();
// 所以,右邊也是同樣
and
// 我們要查詢id大於1並且小於3的資料
$userInfo = User::find()->where(['and' , 'id > 1' , 'id < 3'])->all();
// 或者用以下方式,更為安全
$userInfo = User::find()->where(['and' , ['>' , 'id' , 1] , ['<' , 'id' , 3]])->all();
$userinfo = User::find()->where(['id'=>['1','2']])->asarray()->all();//找出user表中id等於1和2的資料
// 假如我們要查詢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();
// 我們要查詢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();
// 所以,右邊也是同樣