laravel orderByRaw()在查询构建器上

时间:2013-11-19 07:49:54

标签: php mysql laravel laravel-4

现在无法使用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 个答案:

答案 0 :(得分:26)

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

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

$against = 'bar';

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

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