【发布时间】:2017-11-23 07:42:06
【问题描述】:
我正在尝试编写高级 Eloquent 搜索查询过滤器,但是当我返回集合以查看时,出现以下错误
Call to undefined method Illuminate\Database\Query\Builder::links()
我的 Eloquent 查询构建器:
$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),它会返回一个 Builder 实例,但为什么呢?
我的视图代码如下(以防您认为我正在覆盖$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->render() }}
-
link() 是 Catalogo 类的方法吗?
-
@Exprator 它显示了一个类似的错误:
Call to undefined method Illuminate\Database\Query\Builder::render() -
@Extrakun 方法
link()渲染laravel分页的html按钮 -
好的,只需从查询中删除 groupby 就可以了
标签: php mysql laravel query-builder