qd博客

海阔凭鱼跃,天高任鸟飞

mysql FIND_IN_SET方法的使用实例

以下是原来的查询方式:

$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等于当前值的记录排在最前面,如果查询不到那就查询其他的数据,最后得到符合结果的数据。 


<< 1 >>
«   2019年8月   »
1234
567891011
12131415161718
19202122232425
262728293031
网站分类
搜索
最新留言
文章归档
友情链接
    控制面板
    您好,欢迎到访网站!
      查看权限

    Powered By Z-BlogPHP 1.6.4 Valyria

    (陕ICP备19025567号-2)

    召唤伊斯特瓦尔