码迷,mamicode.com
首页 > 数据库 > 详细

mysql FIND_IN_SET方法的使用实例

时间:2019-08-17 17:39:38      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:exp   res   结果   find   mysql   expr   _id   方式   pre   

以下是原来的查询方式:

$inviterUserExt = UserExt::findOne([‘user_id‘ => $inviteUser->id, ‘store_id‘ => $_storeId, ‘is_subscribe‘ => IS_SUBSCRIBE]);
if (!$inviterUserExt) {
    $inviterUserExt = UserExt::findOne([‘user_id‘ => $inviteUser->id, ‘is_subscribe‘ => IS_SUBSCRIBE]);
}

 

因为查询了两次数据库,想减少一次查询,所以使用了find_in_set方法

$order = new Expression("FIND_IN_SET(`store_id`,{$_storeId}) DESC"); 

$inviterUserExt = UserExt::find()
    ->andWhere([‘user_id‘ => $inviteUser->id, ‘is_subscribe‘ => IS_SUBSCRIBE])
    ->orderBy($order)
    ->one();

 

使用find_in_set 将store_id等于当前值的记录排在最前面,如果查询不到那就查询其他的数据,最后得到符合结果的数据。 

 

mysql FIND_IN_SET方法的使用实例

标签:exp   res   结果   find   mysql   expr   _id   方式   pre   

原文地址:https://www.cnblogs.com/liuqd001/p/11369164.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!