全球搜索不与Laravel合作



嗨,嗨,我试图为我的proyect进行特定的搜索,但它不想工作,我正在使用关系,这是我的代码PHP:

public function todos_productos($empresa_id, Request $request)
{

    $empresa = Empresa::find($empresa_id);
    $productos = $empresa->productos()->with('producto_nombre', 'producto_nombre.seccion', 'producto_nombre.linea');
    return Datatables::of($productos)
        ->filter(function ($query) use ($request) {
            if ($request->has('codigo')) {
                $query->where('producto_nombre.codigo', 'like', "%{$request->get('codigo')}%");
            }
        })
        ->make(true);

}

我的JS

$(document).ready(function () {
  empresa = $('#empresa_id').val()
  tablaBusqueda = $('#postTable').DataTable({
    processing: true,
    serverSide: true,
    ajax: {
      url: 'api/productos/todos/' + empresa,
      data: function (d) {
        d.codigo = $('input[name=consulta_producto_codigo]').val()
        d.linea = $('select[name=consulta_producto_linea]').val()
        d.seccion = $('select[name=consulta_producto_seccion]').val()
      }
    },
    columns: [
      {data: 'codigo', name: 'producto_nombre.codigo'},
      {data: 'descripcion', name: 'producto_nombre.descripcion'},
      {data: 'existencias', name: 'existencias'},
      {data: 'precio', name: 'precio'},
      {data: 'stock_minimo', name: 'stock_minimo'},
      {data: 'stock_maximo', name: 'stock_maximo'},
      {data: 'producto_nombre.linea.nombre', name: 'producto_nombre.linea.nombre'},
      {data: 'producto_nombre.seccion.nombre', name: 'producto_nombre.seccion.nombre'}
    ],
    'language':
      {
        'url':
          '../plugins/dataTables.spanish.lang'
      }
  })
})

问题是,当我试图通过Codigo(代码(搜索时,它说没有列Produceo_nombre.codigo,我只用Codigo替换了,但也不工作,有人知道为什么?

$empresa是一个Empresa模型实例。 $productos是(假设(Producto模型的雄辩集合,具有两个急切的关系producto_nombreproducto_nombre.seccion。任何查询都将在(假设(productos表而不是您的关系表上运行。

以下是限制急切负载的方法:https://laravel.com/docs/5.6/eloquent-relationships-voncondanc.constraining-eager-loads

最新更新