Ami*_*mir 11 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;
Run Code Online (Sandbox Code Playgroud)
这将按相关性排序结果,如果我们(现在我们没有!)orderByRaw那么上面的查询将是:
Post::whereRaw("MATCH( `title`, `description` AGAINST( ? IN BOOLEAN MODE))", array('bar'))->orderByRaw("(MATCH( 'title' AGAINST( ? )) DESC", array('bar'))->get();
Run Code Online (Sandbox Code Playgroud)
我打开了这个问题,但它无处可去:https: //github.com/laravel/framework/issues/2134
有什么建议吗?
Ron*_*hof 27
使用Eloquent您可以执行以下操作:
$match = "
match (
`title`,
`description`
) against (
?
IN BOOLEAN MODE
)";
$against = 'bar';
$sql->whereRaw($match, array($against));
$sql->orderByRaw($match . " DESC", array($against));
Run Code Online (Sandbox Code Playgroud)
同样适用于查询生成器,但是您必须进行一些重写.
| 归档时间: |
|
| 查看次数: |
26471 次 |
| 最近记录: |