mysql FIND_IN_SET方法的使用实例

Posted liuqd001

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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等于当前值的记录排在最前面,如果查询不到那就查询其他的数据,最后得到符合结果的数据。 

 

以上是关于mysql FIND_IN_SET方法的使用实例的主要内容,如果未能解决你的问题,请参考以下文章

Mysql函数FIND_IN_SET()的使用方法

mysql中FIND_IN_SET的使用方法

mysql中FIND_IN_SET的使用方法

Mysql函数FIND_IN_SET()的使用方法

mysql 中find_in_set()和in()用法比较

MySQL 中 find_in_set() 函数的使用