SQL Server グループ値のスプライシング: GROUP_CONCAT は必要ありません
データベース管理では、グループ内の異なる行の値を結合することが必要になることがよくあります。たとえば、テーブルでは、単一の ID が複数の値に関連付けられます:
Id | Value |
---|---|
1 | 'A' |
1 | 'B' |
2 | 'C' |
目標は、データを各 ID とそれに関連付けられた値を連結した文字列に変換することです。
Id | Value |
---|---|
1 | 'AB' |
2 | 'C' |
SQL Server には MySQL の GROUP_CONCAT 関数がないため、これを実現するのは難しいように思えるかもしれません。ただし、SQL Server では、ユーザー定義集計関数 (UDF) を使用してこの問題を簡単に解決できます。
有効な文字列連結 UDF を作成するために、「SQL Server で GROUP BY を使用して文字列を連結するにはどうすればよいですか?」という重複した質問で提供されている解決策を分析してみましょう。コア部分は、2 つの文字列パラメータを受け取り、それらを連結して結果を返す集計関数です。この操作を UDF にカプセル化することで、クエリで使用できるようになります。
次は、UDF を作成するコード スニペットです:
<code class="language-sql">CREATE FUNCTION [dbo].[StringConcat](@Val1 VARCHAR(MAX), @Val2 VARCHAR(MAX)) RETURNS VARCHAR(MAX) AS BEGIN RETURN COALESCE(@Val1 + @Val2, '') END;</code>
これで、この UDF を簡単なクエリで使用できるようになります:
<code class="language-sql">SELECT Id, StringConcat(Value, '') AS Value FROM YourTable GROUP BY Id;</code>
最終的なクエリ プランは、このアプローチの効率性を示しています。ユーザー定義の集計関数を使用すると、グループ化された行の値を簡単に連結でき、データベースの課題を効果的に解決できます。
以上がGROUP_CONCAT を使用せずに SQL Server でグループ化された値を連結するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。