php - SQLSTATE[HY000] : General error: 1096 No tables used

标签 php mysql laravel-5

错误是这样说的:

SQLSTATE[HY000]: General error: 1096 No tables used (SQL: select `Marcas`.`nombre` as `Marca`, `Modelo`.`nombre` as `Modelo`, `Vehiculos`.`year` as `Anio`, `Vehiculos`.`id` from `Vehiculos` inner join `Reservaciones` on `Vehiculos`.`id` = `Reservaciones`.`id_vehiculo` inner join `Marcas` on `Vehiculos`.`id_marca` = `Marcas`.`id` inner join `Modelo` on `Vehiculos`.`id_modelo` = `Modelo`.`id` where `Vehiculos`.`id_marca` = 1 and `Marcas`.`id_categoria` = 2 and `Vehiculos`.`id` not in (select *))

这是我在 laravel 中的查询:

public function checkDisponibilityByDate(Request $req){
    $fecha = $req->fecha;

    $vehiculos= Vehiculo::join('Reservaciones', 'Vehiculos.id', '=', 'Reservaciones.id_vehiculo')
    ->join('Marcas', 'Vehiculos.id_marca', '=' , 'Marcas.id')
    ->join('Modelo', 'Vehiculos.id_modelo', '=' , 'Modelo.id')
    ->select('Marcas.nombre as Marca', 'Modelo.nombre as Modelo', 'Vehiculos.year as Anio', 'Vehiculos.id')
    ->where('Vehiculos.id_marca', '=' ,$req->id_marca)
->where('Marcas.id_categoria', '=' ,$req->id_categoria)
->whereNotIn('Vehiculos.id', function($fecha) {
        Reservacion::select('Reservaciones.id_vehiculo')
        ->from('Reservaciones')
          ->where('Reservaciones.fecha', '=', $fecha);
})
->get();
return $vehiculos->toJson();
}

我希望你能帮助我,我正在使用 Laravel 5

最佳答案

我认为如果你想将参数传递给查询,你需要使用 use($fecha)

public function checkDisponibilityByDate(Request $req)
{
    $fecha = $req->fecha;

    $vehiculos= Vehiculo::join('Reservaciones', 'Vehiculos.id', '=', 'Reservaciones.id_vehiculo')
                ->join('Marcas', 'Vehiculos.id_marca', '=' , 'Marcas.id')
                ->join('Modelo', 'Vehiculos.id_modelo', '=' , 'Modelo.id')
                ->select('Marcas.nombre as Marca', 'Modelo.nombre as Modelo', 'Vehiculos.year as Anio', 'Vehiculos.id')
                ->where('Vehiculos.id_marca', '=' ,$req->id_marca)
                ->where('Marcas.id_categoria', '=' ,$req->id_categoria)
                ->whereNotIn('Vehiculos.id', function($query) use ($fecha) {
                    $query->select('id_vehiculo')
                          ->from('Reservaciones')
                          ->where('fecha', '=', $fecha);
            })
            ->get();
    return $vehiculos->toJson();
}  

或者你可以通过单独构造数组来简化whereNotIn

public function checkDisponibilityByDate(Request $req)
{
    $fecha = $req->fecha;
    $check = Reservacion::where('fecha', $fecha)->lists('id_vehiculo');

    $vehiculos= Vehiculo::join('Reservaciones', 'Vehiculos.id', '=', 'Reservaciones.id_vehiculo')
                ->join('Marcas', 'Vehiculos.id_marca', '=' , 'Marcas.id')
                ->join('Modelo', 'Vehiculos.id_modelo', '=' , 'Modelo.id')
                ->select('Marcas.nombre as Marca', 'Modelo.nombre as Modelo', 'Vehiculos.year as Anio', 'Vehiculos.id')
                ->where('Vehiculos.id_marca', '=' ,$req->id_marca)
                ->where('Marcas.id_categoria', '=' ,$req->id_categoria)
                ->whereNotIn('Vehiculos.id', $check)
            })
            ->get();
    return $vehiculos->toJson();
}    

希望这对您有所帮助。

如果您可以分享您的模型和表结构,那么可能会建议其他/纯粹的 Eloquent 之类的方法。

关于php - SQLSTATE[HY000] : General error: 1096 No tables used,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41153880/

相关文章:

php - 根据提供的数量将多个相同的行插入 mysql 数据库

mysql - 在没有 GROUP BY 的情况下选择 COUNT 个相同的值

mysql 已执行但未显示结果

node.js - Laravel 5.4 app.js 代码混淆

laravel-5 - 在Laravel 5的重置密码中用真实域名替换localhost

php - Javascript 在一个 PHP 文件中确认删除(在 href 上)

php - 当我运行此示例时,浏览器上显示意外的奇怪代码

php - dompdf中的图像

mysql - mysql 和 hsqldb 中兼容的 TEXT 字段

laravel - 如何在laravel中获取更新的记录ID?