Heim >Datenbank >MySQL-Tutorial >Wie füge ich aus einer nichtskalaren Unterabfrage mehrere Zeilen in eine SQL Server-Tabelle ein?
Einfügen von Werten in eine Tabelle aus einer nichtskalaren Unterabfrage
In SQL Server das Einfügen von Werten in eine Tabelle basierend auf einer Unterabfrage, die zurückgegeben wird Mehrere Ergebnisse können eine Herausforderung sein. Stellen Sie sich das folgende Szenario vor:
Sie haben zwei Tabellen:
Sie möchten Zeilen mit spezifischen Werten für die Tabelle Preise einfügen group, id und price, wobei die id-Werte von einer Unterabfrage abgeleitet werden, die passende IDs aus auswählt ArtikelTabelle.
Falsch Ansatz:
Der Versuch, eine Unterabfrage mit mehr als einem Ergebnis als Wert für eine Spalte in einer INSERT-Anweisung zu verwenden, kann zu einem Fehler führen, wie die folgende falsche SQL-Anweisung zeigt:
INSERT INTO prices (group, id, price) VALUES (7, (select articleId from article WHERE name LIKE 'ABC%'), 1.50);
Richtige Lösung:
Um dieses Problem zu beheben, verwenden Sie a SELECT-Anweisung, um die gewünschten Werte abzurufen und in die Zieltabelle einzufügen. Weisen Sie die konstanten Werte für die Spalten group und price direkt in der SELECT-Anweisung zu:
insert into prices (group, id, price) select 7, articleId, 1.50 from article where name like 'ABC%';
In dieser Anweisung gibt die Unterabfrage einen Rückgabewert zurück Die Artikel-IDs, die den angegebenen Namenskriterien entsprechen, und die konstanten Werte 7 und 1,50 werden dem explizit zugewiesen Spalten Gruppe und Preis.
Das obige ist der detaillierte Inhalt vonWie füge ich aus einer nichtskalaren Unterabfrage mehrere Zeilen in eine SQL Server-Tabelle ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!