sql >> Database >  >> RDS >> Mysql

Kilometerstand van voertuigen berekenen door af te trekken van voertuigmetingen

Enorm dikke disclaimer: Dit wordt geleverd met nee garantie, maar indien Ik heb uw probleem begrepen en Ik ben niet ergens verkeerd, overweeg het volgende.

Uw tafel is

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

Een mogelijke manier is om eerst een weergave te maken met de datum van de laatste meting van vorige maand (die u kunt veranderen in een andere geneste SELECT als je zo geneigd bent):

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

Gevolgd door

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`

Voor

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

dit resulteert in

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


  1. Extra rijen krijgen - Nadat u lid bent geworden van de 3 tafels met behulp van Left Join

  2. Hoe de Mysql-database opnieuw te synchroniseren als Master en slave een verschillende database hebben in het geval van Mysql-replicatie?

  3. String splitsen op positie van scheidingsteken met behulp van Oracle SQL

  4. Heeft iemand succes gehad met het gebruik van een specifieke landinstelling voor een PostgreSQL-database, zodat tekstvergelijking niet hoofdlettergevoelig is?