Einfügung von Unterabfragewerten mit mehreren Ergebnissen lösen
Sie haben zwei Tabellen, Artikel und Preise, in SQL Server. Sie möchten bestimmte IDs aus „Artikel“ in „Preise“ einfügen, indem Sie eine Unterabfrage zur Auswahl der IDs verwenden. Bei Verwendung des folgenden Codes tritt jedoch der Fehler „Unterabfrage hat mehr als 1 Wert“ auf:
INSERT INTO prices (group, id, price) VALUES (7, (select articleId from article WHERE name LIKE 'ABC%'), 1.50);
Das Problem tritt auf, weil die Unterabfrage mehrere IDs zurückgibt, da es mehrere Artikel geben könnte, die mit „ABC%“ übereinstimmen. ' Kriterien. In solchen Fällen müssen Sie Ihre Abfrage wie folgt ändern:
insert into prices (group, id, price) select 7, articleId, 1.50 from article where name like 'ABC%';
Diese überarbeitete Abfrage gibt neben der Unterabfrage zur Auswahl der Artikel-IDs explizit die konstanten Werte (Gruppe: 7, Preis: 1,50) an. Durch die Trennung der konstanten Werte vermeiden Sie die Auswertung einer Unterabfrage für jede ID und lösen so das Problem mehrerer Ergebniswerte.
Das obige ist der detaillierte Inhalt vonWie gehe ich mit mehreren Ergebnissen aus einer Unterabfrage während des SQL Server INSERT um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!