PHPize Online / SQLize Online  /  SQLtest Online

A A A
Share      Blog   Popular
Copy Format Clear
create table equipment ( id int primary key, equipment_id int, datetime datetime, distance double, speed double ); insert into equipment values (222, 141490, "2021-02-07 23:08:07", 5.48, 0.02), (223, 141490, "2021-02-07 23:10:08", 6.09, 0.02), (224, 141490, "2021-02-07 23:11:01", 6.36, 0.02), (418, 141491, "2021-02-07 22:05:38", 341.65, 0), (419, 141491, "2021-02-07 22:06:03", 341.65, 0), (1065, 141491, "2021-02-08 04:56:22", 172.12, 1.24), (1066, 141491, "2021-02-08 04:55:46", 184.51, 0.72) ; select * from equipment;
Copy Clear
Copy Format Clear
<?php $query = "select * from equipment"; $stmt = $pdo->prepare($query); $stmt->execute(); $equipments = $stmt->fetchAll(PDO::FETCH_ASSOC); $result = array_reduce( $equipments, function($res, $el) { if(!is_array($res[$el["equipment_id"]])) { $res[$el["equipment_id"]] = [ "equipment_id" => 141491, "speed" => [] ]; } array_push( $res[$el["equipment_id"]]["speed"], [ "datetime" => $el["datetime"], "value" => $el["speed"], "distance" => $el["distance"], ] ); return $res; }, [] ); var_export(array_values($result));
Show:  
Copy Clear