記事
· 2020年10月19日 5m read

SQL パフォーマンスリソース

SQL パフォーマンスリソース

SQL のパフォーマンスについて語るとき、最も重要なトピックとして取り上げられるのが「Indices」、「TuneTable」、「Show Plan」の 3 つです。  添付の PDF にはこれらのトピックに関する過去のプレゼン資料が含まれていますので、それぞれの基礎を一度に確認していただけます。  当社のドキュメンテーションでは、これらのトピックの詳細に加え、SQL パフォーマンスの他のトピックについてもカバーしておりますので、下のリンクからお読みください。  eラーニングをご利用いただくと、これらのトピックをもっと深く理解していただけます。  また、開発者コミュニティによる記事の中にも SQL パフォーマンスについて書かれたものが複数ありますので、関連するリンクを下に記載しております。

下に記載する情報には同じ内容が多く含まれています。  SQL パフォーマンスにおける最も重要な要素を以下に紹介します。

  • 利用可能なインデックスの種類
  • あるインデックスの種類を他の種類の代わりに使用する
  • TuneTable がテーブルに集める情報とそれが Optimizer に対して意味する内容
  • Show Plan を読んでクエリの善し悪しを深く理解する方法
  • 以下は InterSystems IRIS SQL のパフォーマンスを詳しく理解するのに役立つリソースです

  • Worldwide Response Center (WRC)。電話番号: 617-621-0700
    WRC をご利用ください。  同センターはユーザーが理解しやすいレベルで SQL パフォーマンスを説明してくれます。  優秀な SQL サポートスタッフが数人おりますが、アドバイザーと直接お話しをされる場合は、お気軽にサポートマネージャーの Brendan Bannon までお問い合わせください。

    [訳注:日本ではカスタマサポートセンター(jpnsup@intersystems.com)にお問い合わせください。]

     
  • InterSystems オンラインドキュメンテーション
    1. 機能紹介:  InterSystems SQL:  https://docs.intersystems.com/irislatestj/csp/docbook/DocBook.UI.Page.cls?KEY=AFL_sqlbasics
    2. 機能紹介: InterSystems 製品での SQL パフォーマンスの最適化:  https://docs.intersystems.com/irislatestj/csp/docbook/DocBook.UI.Page.cls?KEY=AFL_sqlqueryopt
    3. InterSystems SQL 最適化ガイド:  https://docs.intersystems.com/irislatestj/csp/docbook/DocBook.UI.Page.cls?KEY=GSQLOPT
       

  • InterSystems の eラーニング
    1. リソースガイド - Caché SQL を解説: パフォーマンス: https://learning.intersystems.com/enrol/index.php?id=255
    2. リソースガイド – Caché SQL を解説: デザインと実行: https://learning.intersystems.com/enrol/index.php?id=256
    3. SQL クエリの最適化:  https://learning.intersystems.com/course/view.php?id=707
    4. アカデミー:  SQL パフォーマンスの最適化:  https://learning.intersystems.com/course/view.php?id=80
    5. SQL クエリの最適化:  https://learning.intersystems.com/course/view.php?id=1013
       

  • Intersystems 開発者コミュニティ
    1. 知っておくと便利なクエリパフォーマンスのコツとは? ずばり Tune Table です! https://community.intersystems.com/post/one-query-performance-trick-you-need-know-tune-table
    2. InterSystems IRIS が提供する水平拡張性:  https://jp.community.intersystems.com/post/intersystems-irisによる水平スケーラビリティ
    3. 外れ値の選択性とは:  https://community.intersystems.com/post/introduction-outlier-selectivity
    4. 日付範囲クエリの SQL パフォーマンスを改善する:  https://jp.community.intersystems.com/post/日付範囲クエリのsqlパフォーマンスを改善する
    5. 日付範囲クエリの SQL パフォーマンスを改善する (vol2):  https://jp.community.intersystems.com/post/日付範囲クエリのsqlパフォーマンスを改善する-vol2
    6. Caché でカスタムインデックスタイプを作成する方法:  https://jp.community.intersystems.com/post/cachéでのカスタムインデックスタイプの作成
    7. グローバルはデータを保存するための魔法の剣です パート1:  https://jp.community.intersystems.com/post/グローバルはデータを保存するための魔法の剣です- パート1
    8. グローバルはデータを保存するための魔法の剣ですパート2 - ツリー:  https://jp.community.intersystems.com/post/グローバルはデータを保存するための魔法の剣ですパート2-ツリー
    9. Globals – グローバルはデータを保存するための魔法の剣です パート3 - 疎な配列 :  https://jp.community.intersystems.com/post/グローバルはデータを保存するための魔法の剣です-パート3-疎な配列
    10. フリーテキスト検索:SQL開発者が秘密にしているテキストフィールドの検索方法*: 
      https://jp.community.intersystems.com/post/フリーテキスト検索:sql開発者が秘密にしているテキストフィールドの検索方法
    11. ノンアトミック属性のインデックス作成:  https://community.intersystems.com/post/indexing-non-atomic-attributes
    12. 配列プロパティ要素の SQL インデックス:  https://community.intersystems.com/post/sql-index-array-property-elements
       

  • 過去の PowerPoint 資料
  • 付属のプレゼン資料は古いですが、充実した内容になっています。  情報の多くは Intersystems IRIS に該当するものですが、念のために最新のドキュメンテーションをご確認ください。  以下のすべてを PDF ファイルとして本記事に添付しています。

    1. インデックス作成とは
    2. SQL パフォーマンスの最適化 (2015 年版)
    3. %PARALLEL Query のヒント (2016 年版)
    4. Frozen Plans と Parallel Queries (2017 年版)
    5. 生成された COS に対する Show Plan (2013 年版)
    6. SQL プログラミング (2006 年版)

  • (本記事の著作者は Brendan Bannan、編集アシスタントは Cliff Mason と Kyle Baxter です) 

    @Ben Speadさんが書いた元の記事へ
    ディスカッション (0)2
    続けるにはログインするか新規登録を行ってください