嗨,嗨,我试图为我的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_nombre
和producto_nombre.seccion
。任何查询都将在(假设(productos
表而不是您的关系表上运行。
以下是限制急切负载的方法:https://laravel.com/docs/5.6/eloquent-relationships-voncondanc.constraining-eager-loads