Laravel 5.3,调用未定义的方法Illuminate \ Database \ Query \ Builder :: links()
我正在尝试编写高级Eloquent搜索查询过滤器,但是当我返回集合以查看时,出现以下错误Laravel 5.3,调用未定义的方法Illuminate Database Query Builder :: links()
Call to undefined method Illuminate\Database\Query\Builder::links()
我的口才查询生成器:
$catalogos = Catalogo::query();
$catalogos->where('catalogo.subcategoria',$filtro)
->join('productos', 'productos.catalogo_id','=','catalogo.id')
->join('productos_precios','productos_precios.segment','=','productos.codigo_oracle')
->join('fotos_productos','fotos_productos.producto_id','=','productos.id')
->select('catalogo.descripcion', 'catalogo.descripcion_corta','catalogo.id','fotos_productos.nombre as ruta', 'productos_precios.precio')
->whereNotNull('fotos_productos.nombre')
->orderBy('precio', 'asc')
->groupBy('catalogo.id')
->paginate(24);
是的,如果我dd($catalogos)
,它返回我一个生成器实例,但是为什么呢?
我的看法代码如下(以防万一你在想我改写$catalogos
变量的值):
@foreach($catalogos as $catalogo)
<div class="producto_tienda">
<a href="{{route('detalle-producto', [$catalogo->id,$catalogo->slug]) }}">
<div class="foto_producto" style="background-image:url('{{ asset("public/images/tienda/".$catalogo->ruta) }}')">
@if($catalogo->stock>0 && $catalogo->stock<10)
<div class="etiquetas">
<p class="existencia">Últimos productos</p>
</div>
@endif
@if($catalogo->stock==0)
<div class="etiquetas">
<p class="descuento">Agotado</p>
</div>
@endif
</div>
</a>
<a href="{{route('detalle-producto', [$catalogo->id,$catalogo->slug])}}">
<div class="descripcion_producto">{{ $catalogo->descripcion_corta }}</div>
</a>
<div class="precio_producto">{{ money_format('%.2n' ,$catalogo->precio) }}</div>
</div>
@endforeach
<div class="text-center">
{{ $catalogos->links() }}
</div>
现在看来,与此一起工作:
$catalogos = Catalogo::query();
$catalogos = $catalogos->where('catalogo.subcategoria',$filtro)
->join('productos', 'productos.catalogo_id','=','catalogo.id')
->join('productos_precios','productos_precios.segment','=','productos.codigo_oracle')
->join('fotos_productos','fotos_productos.producto_id','=','productos.id')
->select('catalogo.descripcion', 'catalogo.descripcion_corta','catalogo.id','fotos_productos.nombre as ruta', 'productos_precios.precio')
->whereNotNull('fotos_productos.nombre')
->orderBy('precio', 'asc')
->groupBy('catalogo.id')
->paginate(24);
从文档:
Currently, pagination operations that use a groupBy statement cannot be executed efficiently by Laravel. If you need to use a groupBy with a paginated result set, it is recommended that you query the database and create a paginator manually.
你应该按照文档并为您的查询创建一个手动分页器。
https://laravel.com/docs/5.4/pagination#manually-creating-a-paginator
您还没有分配的paginate
到任何东西的返回值。它应该是:
$catalogos = Catalogo::query()->where('catalogo.subcategoria',$filtro)
->join('productos', 'productos.catalogo_id','=','catalogo.id')
->join('productos_precios','productos_precios.segment','=','productos.codigo_oracle')
->join('fotos_productos','fotos_productos.producto_id','=','productos.id')
->select('catalogo.descripcion', 'catalogo.descripcion_corta','catalogo.id','fotos_productos.nombre as ruta', 'productos_precios.precio')
->whereNotNull('fotos_productos.nombre')
->orderBy('precio', 'asc')
->groupBy('catalogo.id')
->paginate(24);
这个想法是将过滤器应用于查询,我不能一次放置所有查询。我需要从'$ catalogos = Catalogo :: query()'开始,然后将每个搜索参数作为修饰符添加到从'$ catalogos = Catalogo :: query();'返回的查询实例中;' –
问题在功能上与此相同。您可以将'query'的结果存储在一个变量中,或者直接使用它,这没有什么区别。设置者[流利](http://go.aopphp.com/blog/2013/03/19/implementing-fluent-interface-pattern-in-php/) – apokryfos
嗯,我明白了你的观点,我解决了这个问题,但我很关心laravel文档中关于“groupBy”语句分页的说法,它现在对我来说工作正常,但我不知道它是否总能正常工作...... –
它表明,如果你使用{{$ catalogos->渲染()}} – Exprator
是链接()的方法对于Catalogo类? – Extrakun
@Exprator它给我看到一个类似的错误:'调用未定义的方法Illuminate \ Database \ Query \ Builder :: render()' –