SHOEISHA iD

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

連載記事

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

翔泳社では、「独習」「徹底入門」「スラスラわかる」「絵で見てわかる」「一年生」などの人気シリーズをはじめ、言語や開発手法、最新技術を解説した書籍を多数手がけています。プロジェクトマネジメントやチームビルティングといった管理職向けの書籍も豊富です。

ITエンジニアとしてのスキルアップ・リスキリングに、ぜひお役立てください。

書籍に関する記事を見る

'); googletag.cmd.push(function() { googletag.pubads().addEventListener('slotRenderEnded', function(e) { var ad_id = e.slot.getSlotElementId(); if (ad_id == 'div-gpt-ad-1659428980688-0') { var ad = $('#'+ad_id).find('iframe'); if ($(ad).width() == 728) { var ww = $(window).width(); ww = ww*0.90; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/728+","+ww/728+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/728+","+ww/728+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/728+","+ww/728+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/728+","+ww/728+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(90*ww/728)+"px;width:"+728+"px;}", 0 ); } else { if ($(window).width() < 340) { var ww = $(window).width(); ww = ww*0.875; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/320+","+ww/320+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/320+","+ww/320+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/320+","+ww/320+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/320+","+ww/320+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(180*ww/320)+"px;width:"+320+"px;}", 0 ); } } } }); }); } else { document.write('
'); document.write('
'); }
難解クエリー言語「MDX」に挑戦

多次元データベースクエリー言語「MDX」入門
~MDX構文の基本文法(1)

第1回

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

 MDXは難解で、習得が困難なクエリー言語であると言われています。この連載では、MDXを可能な限り短期間で実践で使えるレベルまで習得できるよう、使用例とともに入門編として解説します。今回はMDX構文の基本として、メジャーとディメンション、メンバー、タプルとセットの指定の仕方について説明します。

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

はじめに

 MDXは難解で、習得が困難なクエリー言語であると言われています。この連載では、全7回をとおして、難解と言われているMDXを可能な限り短期間で実践で使えるレベルまで習得できるよう、基本的な考え方やよく使う関数などに範囲を限定し、使用例とともに入門編として解説しています。

 なお、本記事はマイクロソフト社製SQL Server 2005および2008のAnalysis Servicesを前提として解説しています。MDXにはいわゆる「方言」が多く、記述内容が他の多次元データベース製品に必ずしも適合しない可能性があることをあらかじめご了承下さい。

 第1回目となる今回は、MDX構文の基本として、メジャーとディメンション、メンバー、タプルとセットの指定の仕方について説明します。

対象読者

  • Microsoft SQL Server Analysis Servicesの基礎知識があり、これからMDXを覚えようという方

必要な環境

  • Microsoft SQL Server 2005 Analysis ServicesまたはMicrosoft SQL Server 2008 Analysis Services

キューブの構造

 リレーショナルデータベースでは、データを2次元のテーブルに格納します。最初に空のテーブルを「CREATE」し、そこにデータを「INSERT」してから「SELECT」します。テーブルという「箱」と、データという「中身」とをはっきり区別できます。

 では、多次元データベースではどうでしょうか?

 多次元データベースはリレーショナルデータベースとは違い、「テーブルにデータを格納する」という考え方自体を捨てなければなりません。多次元データベースのキューブとは「何かにデータが格納されたもの」としてではなく、「多次元的に構造化されたデータそのもののかたまり」としてイメージするべきなのです。

図1:リレーショナルデータベースのテーブルと多次元データベースのキューブの違い
図1:リレーショナルデータベースのテーブルと多次元データベースのキューブの違い

会員登録無料すると、続きをお読みいただけます

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

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

メールバックナンバー

次のページ
キューブの基本構造

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

  • X ポスト
  • このエントリーをはてなブックマークに追加
難解クエリー言語「MDX」に挑戦連載記事一覧

もっと読む

この記事の著者

大家 正巳(オオヤ マサミ)

株式会社ヴィバーク代表取締役。 システムアナリスト。 この度、当社では SQL Server Analysis Services に接続し、MDXの発行が可能な BIシステム構築ツール「CubeWalker」を開発しました。2009年10月より発売致します。 高速かつ安価なBIシステム作りに、是非お...

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

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

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/4334 2009/09/09 14:00
" ); }

おすすめ

アクセスランキング

  1. 1
    ソフトウェアエンジニアの業務効率化を支援する「Kurogo」、フルリニューアルでコード検索機能とWeb情報収集機能が追加
  2. 2
    モバイルデバイス向けのLinux Sailfish OS、バージョン5.0を発表
  3. 3
    C# 13の新機能を理解する――暗黙的なインデックスアクセスとallows ref struct
  4. 4
    「オブザーバー・パターン」 ~マンガでプログラミング用語解説
  5. 5
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──React Server Componentsとその他の改善点
  1. 6
    【超時短テクニカルライティング】生成AIを活用しながら文章を見直して、よりわかりやすい文章にしよう
  2. 7
    ゲーム業界で働くプログラマ・エンジニア、8割超が現在の職場のスキル評価に満足
  3. 8
    AIエージェントエディタ「Windsurf Wave 4」がリリース。AIネイティブIDEに必要とされる機能を多数追加
  4. 9
    無料のオフィススイート「LibreOffice 25.2」がメジャーリリース
  5. 10
    Google Cloud、Anthropicのハイブリッド推論モデル「Claude 3.7 Sonnet」をVertex AIで利用可能に

アクセスランキング

  1. 1
    ソフトウェアエンジニアの業務効率化を支援する「Kurogo」、フルリニューアルでコード検索機能とWeb情報収集機能が追加
  2. 2
    モバイルデバイス向けのLinux Sailfish OS、バージョン5.0を発表
  3. 3
    C# 13の新機能を理解する――暗黙的なインデックスアクセスとallows ref struct
  4. 4
    「オブザーバー・パターン」 ~マンガでプログラミング用語解説
  5. 5
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──React Server Componentsとその他の改善点
  6. 6
    【超時短テクニカルライティング】生成AIを活用しながら文章を見直して、よりわかりやすい文章にしよう
  7. 7
    ゲーム業界で働くプログラマ・エンジニア、8割超が現在の職場のスキル評価に満足
  8. 8
    AIエージェントエディタ「Windsurf Wave 4」がリリース。AIネイティブIDEに必要とされる機能を多数追加
  9. 9
    無料のオフィススイート「LibreOffice 25.2」がメジャーリリース
  10. 10
    Google Cloud、Anthropicのハイブリッド推論モデル「Claude 3.7 Sonnet」をVertex AIで利用可能に
  1. 1
    ITエンジニア本大賞2025、技術書部門とビジネス書部門の大賞が決定!
  2. 2
    「オブザーバー・パターン」 ~マンガでプログラミング用語解説
  3. 3
    マイクロソフト、VSCodeの新機能「Copilot Next Edit Suggestions」のプレビュー版公開
  4. 4
    C# 13の新機能を理解する――暗黙的なインデックスアクセスとallows ref struct
  5. 5
    3/5まで書籍全文が無料公開 『Pythonで動かして学ぶ!Kaggleデータ分析入門』
  6. 6
    AIや統計の数式を解説する美少女VTuber「AIcia Solid Project」生みの親が語る、継続できるアウトプット活動とは?
  7. 7
    Webはどんどん複雑になっている? これまでのWebシステムのトレンドを振り返る
  8. 8
    Linuxディストリビューション「EndeavourOS Mercury」が一般提供開始
  9. 9
    ITエンジニア本大賞2025のプレゼン大会をレポート、最終決戦に臨んだ本に込められた想いとは
  10. 10
    開発者のOSS活動が会社から評価される世の中にしたい──日立製作所が専門組織設立に込めた情熱

イベント

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

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

メールバックナンバー

アクセスランキング

  1. 1
    ソフトウェアエンジニアの業務効率化を支援する「Kurogo」、フルリニューアルでコード検索機能とWeb情報収集機能が追加
  2. 2
    モバイルデバイス向けのLinux Sailfish OS、バージョン5.0を発表
  3. 3
    C# 13の新機能を理解する――暗黙的なインデックスアクセスとallows ref struct
  4. 4
    「オブザーバー・パターン」 ~マンガでプログラミング用語解説
  5. 5
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──React Server Componentsとその他の改善点
  1. 6
    【超時短テクニカルライティング】生成AIを活用しながら文章を見直して、よりわかりやすい文章にしよう
  2. 7
    ゲーム業界で働くプログラマ・エンジニア、8割超が現在の職場のスキル評価に満足
  3. 8
    AIエージェントエディタ「Windsurf Wave 4」がリリース。AIネイティブIDEに必要とされる機能を多数追加
  4. 9
    無料のオフィススイート「LibreOffice 25.2」がメジャーリリース
  5. 10
    Google Cloud、Anthropicのハイブリッド推論モデル「Claude 3.7 Sonnet」をVertex AIで利用可能に

アクセスランキング

  1. 1
    ソフトウェアエンジニアの業務効率化を支援する「Kurogo」、フルリニューアルでコード検索機能とWeb情報収集機能が追加
  2. 2
    モバイルデバイス向けのLinux Sailfish OS、バージョン5.0を発表
  3. 3
    C# 13の新機能を理解する――暗黙的なインデックスアクセスとallows ref struct
  4. 4
    「オブザーバー・パターン」 ~マンガでプログラミング用語解説
  5. 5
    フロントエンドの定番ライブラリ「React 19」の新機能を紹介──React Server Componentsとその他の改善点
  6. 6
    【超時短テクニカルライティング】生成AIを活用しながら文章を見直して、よりわかりやすい文章にしよう
  7. 7
    ゲーム業界で働くプログラマ・エンジニア、8割超が現在の職場のスキル評価に満足
  8. 8
    AIエージェントエディタ「Windsurf Wave 4」がリリース。AIネイティブIDEに必要とされる機能を多数追加
  9. 9
    無料のオフィススイート「LibreOffice 25.2」がメジャーリリース
  10. 10
    Google Cloud、Anthropicのハイブリッド推論モデル「Claude 3.7 Sonnet」をVertex AIで利用可能に
  1. 1
    ITエンジニア本大賞2025、技術書部門とビジネス書部門の大賞が決定!
  2. 2
    「オブザーバー・パターン」 ~マンガでプログラミング用語解説
  3. 3
    マイクロソフト、VSCodeの新機能「Copilot Next Edit Suggestions」のプレビュー版公開
  4. 4
    C# 13の新機能を理解する――暗黙的なインデックスアクセスとallows ref struct
  5. 5
    3/5まで書籍全文が無料公開 『Pythonで動かして学ぶ!Kaggleデータ分析入門』
  6. 6
    AIや統計の数式を解説する美少女VTuber「AIcia Solid Project」生みの親が語る、継続できるアウトプット活動とは?
  7. 7
    Webはどんどん複雑になっている? これまでのWebシステムのトレンドを振り返る
  8. 8
    Linuxディストリビューション「EndeavourOS Mercury」が一般提供開始
  9. 9
    ITエンジニア本大賞2025のプレゼン大会をレポート、最終決戦に臨んだ本に込められた想いとは
  10. 10
    開発者のOSS活動が会社から評価される世の中にしたい──日立製作所が専門組織設立に込めた情熱