Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment référencer un attribut à l'intérieur d'une table à une valeur à l'intérieur d'une nouvelle ligne dans la même table

Si vous n'avez pas de serveur Mysql 8.x, vous pouvez l'utiliser.

CREATE TABLE table1
(`Name_ID {FK}` int, `Completion_Date` varchar(10), `New_Time` int)
;

INSERT INTO table1
(`Name_ID {FK}`, `Completion_Date`, `New_Time`)
VALUES
(001, '16/01/2019', 108),
(001, '16/02/2019', 123),
(001, '16/03/2019', 136)
;

Et vous pouvez l'utiliser

select  `Name_ID {FK}`,`Completion_Date`,@quot old_time, @quot:=`New_Time` new_time
 from table1 p,(SELECT @quot := 0) r
 order by  `Name_ID {FK}`,`Completion_Date`;

pour obtenir ce résultat :

Name_ID {FK}    Completion_Date     old_time    new_time
  1              16/01/2019            0           108
  1              16/02/2019            108         123
  1              16/03/2019            123         136

Il est basé sur ceciSimuler la fonction de décalage dans MySQL