##DataDirect経由でSQLseverとExcelをODBC接続する
本記事ではDataDirectのドライバーを使用してSQLserverとExcelをODBC接続する方法を説明していきます。
DataDirectはサポートしているバージョンの幅がSQL Server 2000~2012と広いことやWire Protocol技術により、SQL Server Clientが必要ないなど性能のオーバヘッドが少ないことが特徴です。今回は現行手に入る最も古いバージョンのSQLsever2012と最新のSQLserver2019を一つのドライバでアクセスする検証をしてみました。
##実行環境
※SQLseverはどちらもローカルに構築した内容となっています。
OS:Windows10
Server,DB:SQLserver2012、2019
##実行手順
インストールの手順については誘導の通り進めれば問題ないため省略しています。
###1. SQLserverのインストール
SQL server2012、2019をインストールします。
SQL serverについて本記事でフォローできていない部分は以下の記事が分かりやすく参考になります。
https://sql55.com/
・SQLserver2012のダウンロードページ
https://www.microsoft.com/ja-jp/download/details.aspx?id=29062
・SQLserver2019のダウンロードページ
https://www.microsoft.com/ja-jp/sql-server/sql-server-downloads
###2. SQL Server Management Studio(以降SSMS)のインストール
データベース、テーブルの作成・操作を行う際に必要になるので、インストールしておきましょう。
・SSMSのダウンロードページ
https://msdn.microsoft.com/ja-jp/library/mt238290.aspx
###3. DataDirectのインストール
DataDirectのドライバーは以下よりダウンロードできます。
https://www.ashisuto.co.jp/datadirect/app_download/
###4. サーバーのポート番号の設定
SQL server 構成マネージャーを開き、「SQL server ネットワークの構成」から「TCP/IP」を有効にします。
「TCP/IP」を右クリックして「プロパティ」を開き、「IPALL」の「TCPポート」に任意のポート番号を設定してください。「OK」をクリックして、ポート番号の設定は完了です。
###5. Windows ODBC Administratorの設定
ODBC Administratorを開いたら、
「ユーザーDSN」→「追加」
"DataDirect 8.0 SQL Server Wire Protocol"を選択して「完了」をクリックします。
追加したユーザーDSNをダブルクリックもしくは「構成」をクリックします。
以下の画面が開くので、任意のデータソース名、ホスト名、設定したポート番号、接続先のデータベース名を設定します。設定ができたら、「Test Connect」で接続を確認して設定は終了です。
###6. SSMSでデータベース、テーブルの作成
SSMSを開き「データベース」を右クリックして、「新しいデータベース」をクリックします。
任意のデータベース名を設定します。ここでは「test2019」としています。
「OK」をクリックすることでデータベースの作成は完了です。
作成したデータベースの「テーブル」を右クリックし、「新規作成」→「テーブル」をクリックします。
列名、データ型、NULLの許容の設定を行います。
作成したテーブルを右クリックして、「上位200行の編集」からテーブルを編集していきます。
今回は検証用として以下のサンプルテーブルを作成しました。
SQL server2012に作成したテーブル
SQL server2019に作成したテーブル
###7. データベースのアクセス許可設定
「セキュリティ」→「ログイン」を右クリックし、「新しいログイン」をクリックします。
「SQL Server認証」にチェックして、ログイン名とパスワードを設定します。
これでSQL認証用のアカウントが作成されます。
###8. エクセルとSQLserverをODBC接続
それではODBC接続でSQL severからデータを取得してExcelに出力してみましょう。
Excelを開き「データタブ」から「データの取得」→「その他のデータソース」→「ODBCから」をクリック。
認証が求められるので、SQL server認証アカウントのアカウント名とパスワードを入力して認証します。
「ナビゲーター」が開いたら、作成したテーブルを選択して「読み込み」をクリックすることでExcelにテーブルを出力することができます。
以下に表示例を示しています。
SQL server2012のデータベースから取得したテーブル
SQL server2019のデータベースから取得したテーブル