这是我的SQL查询
select sum(stock.total_in_stock) as total_in_stock,stock.name,stock.inventory_id FROM ( SELECT i.store_id,i.model_id,i. total_in_stock,i.id as inventory_id, m.* from `inventory` as `i` left join `model_store` as `ms` on `ms`.`store_id` = `i`.`store_id` left join `model` as `m` on `m`.`id` = `ms`.`model_id` where `i`.`model_id` = m.id and `m`.`status` = 1 and `ms`.`status` = 1 and `i`.`created_at` = (select max(si.created_at) from `inventory` as `si` where si.model_id = i.model_id AND si.store_id = i.store_id AND si.status=1 ORDER BY si.created_at DESC LIMIT 1 )) as stock group by `stock`.`model_id`
基本上,我试图在最近的日期检索特定商店的库存。
我已经在laravel中编写了这个查询,如下所示: -
$results = DB::table('inventory as i')
->selectRaw( 'sum(stock.total_in_stock) as total_in_stock,stock.name,stock.inventory_id FROM ( SELECT i.store_id,i.model_id,i. total_in_stock,i.id as inventory_id, m.* ')
->leftJoin('model_store as ms','ms.store_id','=','i.store_id')
->leftJoin('model as m','m.id','=','ms.model_id')
->where('i.model_id','=', 'm.id')
->where('m.status','=', 1)
->where('ms.status','=', 1)
->where('i.created_at','=',function($query){
$query->from('inventory as si')
->selectRaw('max(si.created_at)')
->whereRaw('si.model_id = i.model_id AND si.store_id = i.store_id AND si.status=1 ORDER BY si.created_at DESC LIMIT 1 )) as stock ')
->groupBy('stock.model_id');
})->get();
这给了我以下错误: -
SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1
(SQL: select sum(stock.total_in_stock) as total_in_stock,stock.name,stock.inventory_id FROM ( SELECT i.store_id,i.model_id,i. total_in_stock,i.id as inventory_id, m.* from `inventory` as `i` left join `model_store` as `ms` on `ms`.`store_id` = `i`.`store_id` left join `model` as `m` on `m`.`id` = `ms`.`model_id` where `i`.`model_id` = m.id and `m`.`status` = 1 and `ms`.`status` = 1 and `i`.`created_at` = (select max(si.created_at) from `inventory` as `si` where si.model_id = i.model_id AND si.store_id = i.store_id AND si.status=1 ORDER BY si.created_at DESC LIMIT 1 )) as stock group by `stock`.`model_id`))
我需要应用分页。所以我必须如上所述编写此查询。
我尝试使用DB::select()
编写查询。它返回正确的记录,但不幸的是,我不能使用分页。
请帮我在laravel中编写正确的查询。
答案 0 :(得分:0)
尝试让PDO实例直接执行查询,如下所示:
$PDO=DB::connection('mysql')->getPdo();
$stmt=$PDO->prepare("
select
sum(stock.total_in_stock) as total_in_stock,
stock.name,
stock.inventory_id
FROM
(SELECT
i.store_id,
i.model_id,
i.total_in_stock,
i.id as inventory_id,
m . *
from
`inventory` as `i`
left join `model_store` as `ms` ON `ms`.`store_id` = `i`.`store_id`
left join `model` as `m` ON `m`.`id` = `ms`.`model_id`
where
`i`.`model_id` = m.id
and `m`.`status` = 1
and `ms`.`status` = 1
and `i`.`created_at` = (select
max(si.created_at)
from
`inventory` as `si`
where
si.model_id = i.model_id
AND si.store_id = i.store_id
AND si.status = 1
ORDER BY si.created_at DESC
LIMIT 1)) as stock
group by `stock`.`model_id`
");
// you can use prepared statments too,
// you will need to place :status
// accordingly in your query
//$stmt->bindParam(':status', 1);
$stmt->execute();
$result = $stmt->fetchAll();
祝你好运!