Heim > Datenbank > MySQL-Tutorial > Wie kann ich mit T-SQL mehrere Zeilen in einer einzigen Spalte mit durch Kommas getrennten Werten kombinieren?

Wie kann ich mit T-SQL mehrere Zeilen in einer einzigen Spalte mit durch Kommas getrennten Werten kombinieren?

Patricia Arquette
Freigeben: 2025-01-12 09:53:43
Original
835 Leute haben es durchsucht

How Can I Combine Multiple Rows into a Single Column with Comma-Separated Values Using T-SQL?

Mehrere Werte in einer einzelnen Spalte in T-SQL zurückgeben

Das Abrufen mehrerer Werte aus verschiedenen Zeilen und deren Zusammenführung in einer einzigen Spalte ist eine häufige Aufgabe in einer SQL Server-Umgebung. Dies ist besonders nützlich in Szenarien wie dem Abrufen aller Aliase, die einem bestimmten Benutzer zugeordnet sind.

Um dies effizient zu erreichen, sollten Sie die Verwendung einer benutzerdefinierten Funktion in Betracht ziehen, die die COALESCE-Funktion nutzt. Dieser Ansatz ermöglicht es Ihnen, die abgerufenen Werte schrittweise zu einer einzigen Zeichenfolge zu verketten und so letztendlich die gewünschte Ausgabe bereitzustellen.

Hier ist ein Beispiel für eine Funktion namens GetAliasesById:

<code class="language-sql">CREATE FUNCTION [dbo].[GetAliasesById]
(
    @userID int
)
RETURNS varchar(max)
AS
BEGIN
    declare @output varchar(max)
    select @output = COALESCE(@output + ', ', '') + alias
    from UserAliases
    where userid = @userID

    return @output
END</code>
Nach dem Login kopieren

Nachdem Sie diese Funktion definiert haben, können Sie sie in Ihre Abfrage integrieren, um die gewünschte Ausgabe zu erhalten:

<code class="language-sql">SELECT UserID, dbo.GetAliasesByID(UserID)
FROM UserAliases
GROUP BY UserID</code>
Nach dem Login kopieren

Diese Abfrage gibt eine Tabelle mit zwei Spalten zurück: Benutzer-ID und Aliase. Die Spalte „Aliase“ enthält eine durch Kommas getrennte Liste aller mit jedem Benutzer verknüpften Aliase und erfüllt die angegebene Anforderung, mehrere Werte in einer einzelnen Spalte zurückzugeben.

Das obige ist der detaillierte Inhalt vonWie kann ich mit T-SQL mehrere Zeilen in einer einzigen Spalte mit durch Kommas getrennten Werten kombinieren?. 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