Heim > Datenbank > MySQL-Tutorial > Wie gehe ich mit mehreren Ergebnissen aus einer Unterabfrage während des SQL Server INSERT um?

Wie gehe ich mit mehreren Ergebnissen aus einer Unterabfrage während des SQL Server INSERT um?

Barbara Streisand
Freigeben: 2025-01-06 00:01:41
Original
922 Leute haben es durchsucht

How to Handle Multiple Results from a Subquery During SQL Server INSERT?

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);
Nach dem Login kopieren

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%';
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage