sql >> Databasteknik >  >> RDS >> Mysql

Hur refererar jag ett attribut i en tabell till ett värde inuti en ny rad i samma tabell

Om du inte har en Mysql 8.x-server kan du använda denna.

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

Och du kan använda detta

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

för att få detta resultat:

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

Den är baserad på dennaSimulera fördröjningsfunktion i MySQL



  1. solfläck solr odefinierad fälttyp

  2. mysql gå med i 3 tabeller

  3. Synkronisera databasstruktur mellan applikationer

  4. Syntaxfel på grund av att ett reserverat ord används som tabell- eller kolumnnamn i MySQL