sql >> Databáze >  >> RDS >> Mysql

Vypočítejte ujeté kilometry vozidel odečtením od hodnot vozidla

Zřeknutí se odpovědnosti za velké množství tuku: Toto je dodáváno s ne záruka, ale pokud Rozuměl jsem vašemu problému a Někde se nemýlím, zvažte následující.

Váš stůl je

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

Jedním z možných způsobů je nejprve vytvořit pohled s datem posledního čtení z minulého měsíce (který můžete změnit na další vnořený SELECT pokud jste tak nakloněni):

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

Následuje

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`

Pro

+------+------------+---------+
| 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 |
+------+------------+---------+

výsledkem je

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


  1. ORA-00907:Chybějící pravá závorka při vytváření cizího klíče Oracle 12c

  2. Vytvoření dynamické kontingenční tabulky s funkcí QUOTENAME

  3. Kód chyby:1005. Nelze vytvořit tabulku „...“ (chyba:150)

  4. Jak odstranit index varchar_pattern_ops při migraci django (1.8)?