通八洲科技

如何在 Laravel 的 selectRaw 查询中正确实现多值条件筛选

日期:2025-12-31 00:00 / 作者:聖光之護

本文详解如何在 laravel 中使用 `selectraw` 时,对同一字段(如 `category_id`)进行多个值的匹配,指出 `where category_id = 1 and category_id = 2` 在逻辑上不可能成立,并推荐使用 `wherein()` 实现“或”语义的多值查询。

在 Laravel 的查询构建器中,::selectRaw() 是执行自定义 SQL 字段选择的常用方式,但它本身不改变 where 子句的语义逻辑。你当前的写法:

->where('category_id', '=', 1)
->where('category_id', '=', 2)

等价于 SQL 中的 WHERE category_id = 1 AND category_id = 2 —— 这永远返回空结果,因为单行记录的 category_id 不可能同时等于两个不同整数值。

✅ 正确做法是使用 whereIn() 方法,它对应 SQL 的 IN 子句,语义为“匹配任意一个值”,即 WHERE category_id IN (1, 2):

$query = self::selectRaw(is_array($fields) ? implode(', ', $fields) : $fields)
    ->whereIn('category_id', [1, 2])
    ->where(function ($q) use ($search) {
        if ($search) {
            $q->where('group_name', $search); // 推荐显式写法,避免数组语法歧义
        }
    });

⚠️ 注意事项:

总结:WHERE column = A AND column = B 永假;应根据业务意图选择 whereIn()(任一匹配)、whereExists()(关联存在性)或聚合查询(全量满足)。在 selectRaw 场景下,语法与普通查询构建器完全一致,无需额外适配。