Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Oblicz przebieg pojazdów, odejmując od odczytów pojazdu

Ogromne wyłączenie odpowiedzialności: Pochodzi z nie gwarancja, ale jeśli Rozumiem Twój problem i Gdzieś się nie mylę, rozważ następujące kwestie.

Twój stół jest

CREATE TABLE `foo` (`id` INTEGER, `date` DATE, `mileage` INT);

Jednym z możliwych sposobów jest najpierw utworzenie widoku z datą ostatniego odczytu z ostatniego miesiąca (który można przekształcić w inny zagnieżdżony SELECT jeśli masz taką skłonność):

CREATE VIEW `past_month_readings` 
AS (SELECT `id`, 
    max(`date`) AS `latestreading`
    FROM `foo` 
    WHERE MONTH(`date`) = MONTH(NOW())-1 
    GROUP BY `id`);

Obserwowani przez

SELECT `currentmileages`.`id`, `currentmileage`-`previousmileage` FROM 
 (SELECT `foo`.`id`, `mileage` AS `currentmileage` 
  FROM `foo` 
  JOIN (SELECT `id`, MAX(`date`) AS `latestreading` FROM `foo` GROUP BY `id`) 
  AS `baz` 
  ON `foo`.`id` = `baz`.`id`
  AND `foo`.`date` = `baz`.`latestreading`
 ) 
AS `currentmileages`
JOIN
 (SELECT `foo`.`id`, `mileage` AS `previousmileage` 
  FROM `foo` 
  JOIN `past_month_readings` 
  ON `foo`.`id`=`past_month_readings`.`id` 
  AND `foo`.`date` = `past_month_readings`.`latestreading`)
AS `previousmileages`
ON
`currentmileages`.`id` = `previousmileages`.`id`

Dla

+------+------------+---------+
| id   | date       | mileage |
+------+------------+---------+
|    1 | 2015-06-15 |    1234 |
|    1 | 2015-07-15 |    1444 |
|    1 | 2015-07-25 |    2000 |
|    2 | 2015-06-01 |     100 |
|    2 | 2015-06-20 |     200 |
|    2 | 2015-07-20 |     300 |
+------+------------+---------+

skutkuje to

+------+------------------------------------+
| id   | `currentmileage`-`previousmileage` |
+------+------------------------------------+
|    1 |                                766 |
|    2 |                                100 |
+------+------------------------------------+


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wstaw wiele danych do MySQL i zaktualizuj, jeśli istnieją

  2. profiler mysql Wysyłanie danych

  3. SELECT SUM() z warunkami w mysql

  4. Różnica w sortowaniu utf8 między Unicode a duńskim

  5. błąd separatora mysql