mysql-Laravel-将SQL_CALC_FOUND_ROWS与预先加载的关系一起使用会返回错误的计数
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql-Laravel-将SQL_CALC_FOUND_ROWS与预先加载的关系一起使用会返回错误的计数,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1447字,纯文字阅读大概需要3分钟。
内容图文
![mysql-Laravel-将SQL_CALC_FOUND_ROWS与预先加载的关系一起使用会返回错误的计数](/upload/InfoBanner/zyjiaocheng/883/b7fcb788b9f54d729f15b8a08d5d59a6.jpg)
在我的Laravel应用中,我正在对模型(ModelA)进行普通查询,同时使用SQL_CALC_FOUND_ROWS,然后执行SELECT FOUND_ROWS()以检索所有记录的计数,因为第一个查询使用了LIMIT和OFFSET.
这工作得很好,但是现在我已经在上面查询的模型中添加了关系,如果我执行相同的查询但使用with->(‘modelB’),则此查询将在初始查询之后且之前执行SELECT FOUND_ROWS(),这样我就得到了ModelB结果的计数,而不是我所期望的ModelA.
有没有一种方法可以按我期望的方式在我得到第一个(主)查询而不是关系的计数时工作?
例如这工作正常:
$query = ModelA::select([DB::raw("SQL_CALC_FOUND_ROWS *")])
->where('active', 1);
// conditional ->where()'s
$query->skip(intval($skip))
->take(intval($take))
->orderBy($column, $dir);
$results = $query->get();
$total = DB::select(DB::raw("SELECT FOUND_ROWS() AS 'total';"))[0]->total;
但是将第一行更改为:
$query = ModelA::with('modelB')
->select([DB::raw("SQL_CALC_FOUND_ROWS *")])
->where('active', 1);
一种解决方法是不急于加载而单独获取每个关系,但是在以后的代码中遍历结果时,每个结果都会有一个查询.
解决方法:
通过FOUND_ROWS()可用的行计数是临时的,并且不能在SELECT SQL_CALC_FOUND_ROWS语句之后的语句之后可用.如果以后需要引用该值,请保存它…
Eloquent’s eager loading将使with方法中的每个关系都执行一条额外的select语句.
因此,FOUND_ROWS()将返回最后一个SELECT语句(热切加载的关系)的计数.
要解决此问题,您可以使用lazy eager loading.
$books = App\Book::with('author.contacts')->get();
采用:
$books = App\Book::all();
$count = DB::select(DB::raw('SELECT FOUND_ROWS()'));
$books->load('author.contacts');
内容总结
以上是互联网集市为您收集整理的mysql-Laravel-将SQL_CALC_FOUND_ROWS与预先加载的关系一起使用会返回错误的计数全部内容,希望文章能够帮你解决mysql-Laravel-将SQL_CALC_FOUND_ROWS与预先加载的关系一起使用会返回错误的计数所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。