Mysql
 sql >> база данни >  >> RDS >> Mysql

Изчислете пробега на превозните средства чрез изваждане от показанията на превозните средства

Отказ от отговорност за огромни мазнини: Това идва с не гаранция, но ако Разбрах проблема ви и Не греша някъде, помислете за следното.

Вашата маса е

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

Един възможен начин е първо да създадете изглед с датата на последното четене от миналия месец (което можете да превърнете в друг вложен SELECT ако сте толкова склонни):

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

Последвано от

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`

За

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

това води до

+------+------------------------------------+
| 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. Преобразувайте датата, създадена от jquery datepicker, в стандартен формат за дата на mysql

  2. INSERT IGNORE увеличава брояча на автоматично нарастване, дори да не е добавен запис?

  3. Presto еквивалент на MySQL group_concat

  4. първичният ключ на персонализиран идентификатор не може да бъде извлечен след метода Laravel save().

  5. Групово вмъкване на свързани с MySQL таблици от bash