我有一个棘手的案例...
以下数据库查询不起作用:
DB::table('posts')
->select('posts.*', DB::raw($haversineSQL . ' as distance'))
->having('distance', '<=', $distance)
->paginate(10);
它失败并显示消息:列距离不存在。
当 paginate() 尝试使用以下命令对记录进行计数时会发生错误
select count(*) as aggregate from {query without the column names}
由于列名被删除,距离未知并且会引发异常。
在这种情况下,有人可以解决可以使用分页的问题吗?
Thanks
您可以计算距离WHERE
part:
DB::table('posts')
->whereRaw($haversineSQL . '<= ?', [$distance])
->paginate(10);
如果您需要distance
您的应用程序中的值,您必须计算两次:
DB::table('posts')
->select('posts.*', DB::raw($haversineSQL . ' as distance'))
->whereRaw($haversineSQL . '<= ?', [$distance])
->paginate(10);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)