时间:2021-07-01 10:21:17 帮助过:2人阅读
以下是原来的查询方式:
$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