SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

進化したSQL Server 2012の新機能紹介

数十倍の性能改善を実現させうる列ストアインデックス

進化したSQL Server 2012の新機能紹介(1)

  • X ポスト
  • このエントリーをはてなブックマークに追加

列ストアインデックスの作成とクエリヒント

 列ストアインデックスは、SQL Server Managment Studio 2012の画面操作でも、T-SQLの発行でも作成できます。

 SQL Server Management Studio 2012で列ストアインデックスを作成するには、オブジェクトエクスプローラーを使用します。テーブルツリーの下にあるインデックスで右クリックをし、コンテキストメニューから[新しいインデックス]-[非クラスタ化Columnstoreインデックス]を選択します。

SQL Server Management Studio 2012での列ストアインデックスの作成
SQL Server Management Studio 2012での列ストアインデックスの作成

 T-SQLで作成する場合には、次のようなクエリを発行します。列ストアインデックスは、クラスタ化インデックス(※注2)にできないため、必ず非クラスタ化インデックスになるため、クエリも「NONCLUSTERED」になります。

※注2

 SQL Serverの従来のインデックスには、クラスタ化インデックスと非クラスタ化インデックスの2種類あります。クラスタ化インデックスは、実データを保持しますが、非クラスタ化インデックスはデータへのポインタを保持しています。

[リスト]列ストアインデックスを作成するT-SQL
CREATE NONCLUSTERED COLUMNSTORE INDEX インデックス名 ON テーブル名 (列名,列名...)

 列ストアインデックスを作成するのに必要な時間は、クラスタ化インデックスを作成するのに必要な時間のおよそ1.5倍です。100万行以下のテーブルの場合は、シングルスレッドで列ストアインデックスを作成します。100万行以上の場合は、列ストアインデックスを作成するのに使用できるメモリ容量とMaxDOPの設定に従って並列化して作成されます(※SQL Serverはクエリを並列処理したほうが効率が良いと判断した場合に並列処理をします。MaxDOPは最大並列処理の指定です。例えば、MaxDOPが5の場合、5つのスレッドで並列処理をします)。

 列ストアインデックスを作成すると、後は通常通りSELECT文を発行すると、クエリオプティマイザが必要に応じて列ストアインデックスを使用します。クエリヒントを使用することで、列ストアインデックスを使用した実行計画を作成するように指定できます。

[リスト]列ストアインデックスの使用を指定するクエリヒント
SELECT 列名 FROM テーブル名 WITH( INDEX (列ストアインデックス名) )

 逆に、列ストアインデックスを使用しないようにすることもできます。列ストアインデックスを使用したくない場合は、次のように「OPTION (IGNORE_NONCLUSTERED_COLUMNSTORE_INDEX)」句を指定することで、列ストアインデックスを使用しない実行計画が作成されます。

[リスト]列ストアインデックスを使用しないように指定するクエリヒント
SELECT 列名 FROM テーブル名 OPTION (IGNORE_NONCLUSTERED_COLUMNSTORE_INDEX)

列ストアインデックスのあるテーブルの更新

 SQL Server 2012 RC0時点では、列ストアインデックスがあるテーブルは更新できません。列ストアインデックスのあるテーブルにInsert、Update、Deleteなどの更新処理をすると、「columnstoreインデックスを含むテーブルのデータを更新することはできません。INSERTステートメントを実行する前にいったんcolumnstoreインデックスを無効にし、INSERTの完了後に再構築することを検討してください。」というエラーが発生します。

列ストアインデックスのあるテーブルを更新しようとした時のエラー
列ストアインデックスのあるテーブルを更新しようとした時のエラー

 列ストアインデックスがあるテーブルを更新するには、エラーメッセージにて示されているように、列ストアインデックスを一度無効にしてから更新し、また列ストアインデックスを作成する必要があります。無効にした後、再度列ストアインデックスを作成する際には、最初に列ストアインデックスを作成する時と同じ時間がかかります。

 MSDNライブラリでは、無効にして更新する方法とは別に、パーティションの切り替えでの対応、UNIONALLを使用した対応が紹介されているので、検討したい場合はMSDNライブラリを参照してください。

まとめ

 列ストアインデックスは、大容量のテーブルに作成すると性能向上が期待できます。大容量で、更新頻度が少ないテーブルの場合は列ストアインデックスの作成を検討すると良いでしょう。列ストアインデックスを作成する場合には、テーブルのすべての列を追加します。列ストアインデックスを作成すると更新ができなくなるので、更新方法や更新タイミングについては別途検討が必要です。

 一般的に、25~100倍の性能向上が期待できるので、大容量データを扱う際には、ぜひ列ストアインデックスの使用を検討してください。

参考情報

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
進化したSQL Server 2012の新機能紹介連載記事一覧

もっと読む

この記事の著者

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

WINGSプロジェクト 大和屋 貴仁(ヤマトヤ タカヒト )

WINGSプロジェクトについて> 有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS Twitter: @yyamada(公式)、@yyamada/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/6397 2012/02/21 14:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング