0

大家好,我正在尝试对我的项目进行特定搜索,但它不想工作,我正在使用关系这是我的代码 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(code) 搜索时,它说没有 producto_nombre.codigo 列,我只用 codigo 替换了它,但也不起作用,有人知道为什么吗?

4

1 回答 1

0

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

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

于 2018-02-27T06:26:32.397 回答