查询构建器上的 laravel orderByRaw()

Posted

技术标签:

【中文标题】查询构建器上的 laravel orderByRaw()【英文标题】:laravel orderByRaw() on the query builder 【发布时间】:2013-12-02 16:14:25 【问题描述】:

目前无法使用 Laravel 查询构建器进行这样的查询(使用绑定):

SELECT * FROM `posts` WHERE MATCH( `title`, `description` AGAINST( 'bar' IN BOOLEAN MODE)) ORDER BY (MATCH( 'title' AGAINST( 'bar' )) DESC;

这将按相关性对结果进行排序,如果我们有(我们现在没有!)orderByRaw,那么上面的查询将是:

Post::whereRaw("MATCH( `title`, `description` AGAINST( ? IN BOOLEAN MODE))", array('bar'))->orderByRaw("(MATCH( 'title' AGAINST( ? )) DESC", array('bar'))->get();

我打开了这个问题,但它没有得到任何地方: https://github.com/laravel/framework/issues/2134

有什么建议吗?

【问题讨论】:

【参考方案1】:

使用 Eloquent,您可以执行以下操作:

$match = "
    match (
        `title`,
        `description`
    ) against (
        ?
        IN BOOLEAN MODE
    )";

$against = 'bar';

$sql->whereRaw($match, array($against));
$sql->orderByRaw($match . " DESC", array($against));

同样适用于查询生成器,但是您必须进行一些重写。

【讨论】:

好像orderByRaw是在最新版本中实现的。 我没有看查询生成器,但是 Eloquent 确实支持这个很久了。我已经在 Laravel 4.0.* 上使用了几个月。 Eloquent 对其查询使用相同的 Query\Builder 类。 @Amir:Eloquent 使用 QueryBuilder,但 QueryBuilder 不使用 Eloquent。 codebyjeff.com/blog/2015/02/laravel-quick-tip-order-by-raw 展示了如何将 orderByRaw 与 FIELD 一起使用,这实际上是一回事

以上是关于查询构建器上的 laravel orderByRaw()的主要内容,如果未能解决你的问题,请参考以下文章

在 Java 中抽象出模型构建器上的字段创建

列出队列管理器上的所有队列

目标 C 中选择器上的 EXC_BAD_ACCESS

Stack Exchange 数据资源管理器上的 SQL - 定义值

Laravel 5.2 - pluck() 方法返回数组

使用 Laravel 查询构建器方法 whereIn() 和子查询