ホームページ > データベース > mysql チュートリアル > SQL Serverの列に行を効率的に変換するにはどうすればよいですか?

SQL Serverの列に行を効率的に変換するにはどうすればよいですか?

Barbara Streisand
リリース: 2025-01-25 14:37:09
オリジナル
305 人が閲覧しました

How to Efficiently Convert Rows to Columns in SQL Server?

SQL Serverの中程度の回転変換

質問

特に大規模なデータセットを扱う場合は、SQL Serverのパフォーマンスチャレンジになる可能性があります。この記事では、行の変換を最適化するためのさまざまな方法について説明します。

ピボット関数

ピボット関数は、このタスクの一般的な選択です。常に最速の方法ではありませんが、直接的で柔軟な変換方法を提供します。 ポリマー機能と症例式

PIVOTの交換方法は、ポリマー機能と症例式を使用することです。
<code class="language-sql">SELECT FirstName, Amount, PostalCode, LastName, AccountNumber
FROM (
  SELECT value, columnName
  FROM yourTable
) d
PIVOT (
  MAX(value)
  FOR columnName IN (FirstName, Amount, PostalCode, LastName, AccountNumber)
) piv;</code>
ログイン後にコピー

複数の接続

ピボットまたは重合関数の場合、複数の接続を使用できます。

ダイナミックピボット
<code class="language-sql">SELECT
  MAX(CASE WHEN columnName = 'FirstName' THEN value END) Firstname,
  MAX(CASE WHEN columnName = 'Amount' THEN value END) Amount,
  MAX(CASE WHEN columnName = 'PostalCode' THEN value END) PostalCode,
  MAX(CASE WHEN columnName = 'LastName' THEN value END) LastName,
  MAX(CASE WHEN columnName = 'AccountNumber' THEN value END) AccountNumber
FROM yourTable;</code>
ログイン後にコピー

変換する必要がある不明なケースの場合、動的なSQLを使用してピボットステートメントを作成できます。

以上がSQL Serverの列に行を効率的に変換するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート