sql >> Database >  >> RDS >> Mysql

select statement binnen insert statement in sql retourneert meerdere rijen

de totale vraag ziet er ongeveer zo uit als hieronder. waar je dus de * vervangt door kolomnamen die je wilt selecteren!

INSERT INTO table1(first,second,third)

-- replace * with columns name first,second,third
select * from (
-- START YOU'RE select query
(SELECT table2.timemodified FROM `xtable` AS table2,`ytable` AS table3 
        WHERE table3.id = table2.contextid),

    (SELECT table4.id FROM `ztable` AS table4,`ytable` AS table3 WHERE table4.id = table3.instanceid),

    (SELECT murs.id FROM `table5` AS murs,
    `xtable` AS table2, 
    `wtable` AS table6, 
    `ytable` AS table3, 
    `vtable` AS table7 
    WHERE murs.id = table2.userid AND table6.id = table2.roleid AND table3.id = table2.contextid AND table7.instance = table3.instanceid AND table6.id =3)
-- END YOU'RE select query
)

Ik heb je select-statements naar een subquery verplaatst, zodat je het totale resultaat van de subquery's in je voordeel kunt gebruiken.




  1. SQL Server 2016:Designer bekijken

  2. Eenvoudig voorbeeld van veel-op-veel-relaties met Sequelize

  3. MySQL-functie om de nabijheid/bereik van de postcode te bepalen

  4. Foutcode:1406. Gegevens te lang voor kolom - MySQL