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

假设我们有一个名为`element_instance`的表,它有两个字段:`id`和`parent_id`,其中`id`是元素实例的唯一标识符,`parent_id`指向该元素实例的父级元素。我们需要通过多个子`id`查询它们的所有父级元素,并去重。下面是一个详细的过程: 1. 将多个子`id`以逗号分隔组成一个字符串,例如:`'1,2,3'`。 2. 使用MySQL的`FIND_IN_SET`函数将子`id`字符串拆分成多个子`id`,并对每个子`id`进行查询: ``` SELECT DISTINCT parent_id FROM element_instance WHERE FIND_IN_SET(id, '1,2,3') > 0; ``` 该查询使用`FIND_IN_SET`函数查找`id`字段在`'1,2,3'`中的位置,如果返回值大于0,则说明该`id`在子`id`列表中,查询返回该`id`的父级元素的`parent_id`。 3. 将上述查询结果作为子查询嵌入到一个更大的查询中,使用`DISTINCT`关键字对父级元素的`parent_id`进行去重: ``` SELECT DISTINCT parent_id FROM element_instance WHERE id IN ( SELECT DISTINCT parent_id FROM element_instance WHERE FIND_IN_SET(id, '1,2,3') > 0 ); ``` 该查询先通过子查询获取所有匹配的父级元素的`parent_id`,然后再在`element_instance`表中查找这些父级元素的详细信息,并使用`DISTINCT`关键字对`parent_id`进行去重,最终返回所有匹配的父级元素的`parent_id`。 需要注意的是,这个查询可能会比较慢,特别是当`element_instance`表中的数据量很大时。在实际应用中,可以考虑对`id`和`parent_id`字段添加索引来加速查询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值