Laravel 原始 SQL 查询,具有多次出现的命名绑定

Posted

技术标签:

【中文标题】Laravel 原始 SQL 查询,具有多次出现的命名绑定【英文标题】:Laravel Raw SQL Queries with named bindings for multiple occurences 【发布时间】:2020-03-29 00:39:28 【问题描述】:

我正在使用 DB 外观和选择方法来运行带有绑定的原始 SQL 查询。只需要知道我们是否可以在查询中有多个同名的参数,并通过仅提供 1 个与参数名称的绑定来替换它。

例如

 $sql = "SELECT students.id, students.name FROM students 
                where students.student_id = :student_id 
                where added_on = ( SELECT MAX( added_on ) AS newdate
                FROM students WHERE student_id = :student_id)"

    return DB::select($sql, [
        'student_id' => 1
    ]);

注意:我可能不必在此查询中使用 student_id 两次。它只是一个例子。 目的是知道我们是否能做到这一点。

【问题讨论】:

这能回答你的问题吗? Laravel complains about query with duplicate named parameters 【参考方案1】:

我不相信它可能,这并不理想,但我通常会这样做:

$sql = "SELECT students.id, students.name FROM students 
                where students.student_id = :student_id_1
                where added_on = ( SELECT MAX( added_on ) AS newdate
                FROM students WHERE student_id = :student_id_2)"

    $student_id = 1;

    return DB::select($sql, [
        'student_id_1' => $student_id,
        'student_id_2' => $student_id
    ]);

【讨论】:

以上是关于Laravel 原始 SQL 查询,具有多次出现的命名绑定的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Laravel 的流畅查询构建器混合原始 SQL 和非原始 SQL

在 Laravel 4 中转义原始 SQL 查询

原始 SQL 到 laravel 查询

在 Laravel 5 Eloquent 中获取原始 SQL 查询的结果

Laravel查询范围具有动态值

将原始 SQL 转换为 Laravel 查询构建器