簡體   English   中英

Laravel 5.3,調用未定義的方法Illuminate \\ Database \\ Query \\ Builder :: links()

[英]Laravel 5.3, Call to undefined method 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) ,它返回一個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>

您沒有將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 = $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);

從文檔:

目前,Laravel無法有效執行使用groupBy語句的分頁操作。 如果需要使用具有分頁結果集的groupBy,建議您查詢數據庫並手動創建分頁器。

您應該遵循文檔並為查詢創建手動分頁器。

https://laravel.com/docs/5.4/pagination#manually-creating-a-paginator

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM