sql >> Database >  >> RDS >> Mysql

Hoe verwijs ik naar een attribuut in een tabel naar een waarde in een nieuwe rij binnen dezelfde tabel?

Als u geen Mysql 8.x-server heeft, kunt u deze gebruiken.

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)
;

En je kunt dit gebruiken

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`;

om dit resultaat te krijgen:

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

Het is gebaseerd op dezeSimuleer lag-functie in MySQL



  1. Een POST-verzoek verzenden met formuliergegevens en parameters in PL/SQL

  2. Converteer tekstwaarde in SQL Server van UTF8 naar ISO 8859-1

  3. Samengestelde MySql-sleutels en null-waarden

  4. Hoe verbinding te maken met mysql met behulp van ipv6 van wordpress