O
INSERT
statment tem duas variações:INSERT INTO tableX
(a, b, c, ...)
VALUES
(1, 2, 3, ...) ;
e
INSERT INTO tableX
(a, b, c, ...)
SELECT
1, 2, 3
FROM
... ; --- the same or another table or many tables
O
dual
é uma tabela de sistema com exatamente 1 linha. Pode ser usado para várias coisas. Aqui é usado então um VALUES (...)
é reescrito como um SELECT ...
onde não temos nenhuma tabela adequada para colocar no FROM
cláusula:$query_land = "INSERT INTO `Sequence` (`num_arr`,`start`,`fin`,`way_id`)
SELECT '".$solution[$i][0]."','".$solution[$i][1]."',
'".$solution[$i][2]."','".$solution[$i][3]."'
FROM dual
WHERE '".$solution[$i][0]."' IN (SELECT num_arr
FROM Schedule
WHERE num_arr<>'')";