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

  • 相关阅读:
    【POJ
    【POJ
    【POJ
    【POJ
    【POJ
    【POJ
    【POJ
    【POJ
    NAT
    OSPF与ACL综合实验
  • 原文地址:https://www.cnblogs.com/liuqd001/p/11369164.html
Copyright © 2011-2022 走看看