Lotus Domino / Notes (IBM) のデータベースを、Microsoft SQL Server のリンクサーバ機能を利用してアクセスしてみます。難渋しないよう、メモをしておきます。
実現のきも
- ノーツクライアントのインストールされているOS上にODBCドライバとSQLServerをインストールする場合は、WindowsOS のアーキテクチャが64ビットであっても32ビット版を使います。ノーツクライアントの 64bit 版が現れたら、64ビット版のODBCドライバーとSQLServerが使えるようになるでしょう。
- Dominoサーバー(64bit版)と同じOSに導入する場合は、ODBCドライバーもSQLServerも64ビット版を使います。
試してみる
構成
これは、私が検証した構成です。他の構成でも使えると思います。
- ドミノコンピュータ
- Windows Server 2008 R2
- Lotus Domino Server 8.5.2 / 9.0.1 (今回利用するデータの源泉)
- SQLサーバコンピュータ
- Windows Server 2008 R2
- SQL Server データベース 32ビット版(私は 2014 Express を使用してみました。外部から TCP 接続でログインできるようにしておきます(TCP/IP 有効化とファイアウォール定義))
- Lotus Notes クライアント(DominoServer へログインできる状態まで、設定を行っておきます。Basic と Standard はどちらでもよいです)
- NotesSQL ODBC ドライバ 32ビット版(無償。IBM のサイトからダウンロードできます)
- クライアント
- Windows 7 / Windows 10
- SQL Sever Management Studio(MSSQLServer へ接続できるようにしておきます)
クライアントですること
- SQL Server Management Studio を開き、MSSQLServer へ管理者権限(リンクサーバ登録などができるユーザー)でログインします。
- オブジェクト エクスプローラー内から「リンク サーバ」項目をさがし出します。右クリックをして「新しいリンク サーバ」を選択します。
- 「全般」ページで、リンクサーバー欄に任意のリンクサーバーの名前を入力します。種類には「その他のデータソース」を選択し、プロバイダーには Microsoft OLE DB Provider for ODBC Drivers を選択し、プロバイダー文字列に DSN=データソース名 を入力します。他は空欄で大丈夫です。
- 「セキュリティ」ページで、「このセキュリティ コンテキストを使用する」を選択、リモートログイン欄には、ノーツユーザー名(ドメイン名まできちんと入力)、パスワード欄にはノーツユーザーのログインパスワードを入力します。
- OK ボタンをクリックします。エラーが出ずに登録されればリンクサーバの登録が終わりました。
- 登録されたリンクサーバの項目から、テーブルやビューを展開してみます。一覧が表示されたら、無事接続できたと考えて大丈夫です。
クエリーしてみる
- クライアントで SQL Server Management Studio を開き、MSSQLServer へログインします。
- SQLペインで、次のような SQL 文を記述して発行してみます。
-- リンクサーバ名に引用符は不要
-- ノーツのビュー名は [] などで囲ったりしないでそのまま記述する
SELECT * FROM OPENQUERY(リンクサーバ名, 'SELECT * FROM ノーツのビュー名');
検索結果は表示されたでしょうか?
Tips
公式ドキュメントがあります(英語)。
(下記内容はドキュメント参照前に記載したものもあります)
データ取得方法についてのTips
- どんな DDL が使える?
- ALTER TABLE, CREATE INDEX, CREATE TABLE, CREATE VIEW, DROP INDEX, DROP TABLE, DROP VIEW が使えます(公式ドキュメント Summary of supported ODBC SQL grammar より)
- SELECT 文の文法は?
- SELECT [DISTINCT] {*|列リスト} FROM ... WHERE ... GROUP BY ... HAVING ... UNION ... のようです(公式ドキュメントより)
- 列のデータ型の種類は?
- フォームに関しては、公式ドキュメントの "Data types" に対応表があります。ビューに関しては、すべてVARCHAR(SQL_VARCHAR)で返されます(公式ドキュメント "Using SQL tables derived from Notes forms and views" より)
- どんな比較演算子を使える?
- <, >, <=, >=, =, <>, BETWEEN, IN, LIKE, NOT, ANY, SOME(ANY と同じ), ALL, EXISTS が使えます(公式ドキュメント "Predicate operators" より)
- どんな関数を使える?
- AVG, COUNT, MAX, MIN, SUM が使えます(公式ドキュメント Column functions より)
- NoteID や更新日時などを得たい(疑似列)
- 公式ドキュメントの Using Notes internal fields によると、NotesID, NoteRef, NoteCreated, NoteModified, NoteAccessed, NoteFile, NoteForm, NoteFormType, NoteUNID, NoteRefUNID, NoteConflict の内部列名を利用できるようです。
- NotesUrlを得たい
- こちらの方の情報「NotesURLを作成する方法(@関数の場合) のおつ -Notes/Dominoに関すること-」が有用です。感謝!!
- ビューの列名が、見出し(ヘッダ)と違って _$1 とか _$25 とかなっている
- 暗黙で割り振られるようですが、デザイナから変更できます。ビュー列のプロパティのプログラムの使用セクションに「名前」項目があるので、ここに指定すれば変更できます(公式ドキュメント "Using SQL tables derived from Notes forms and views" より)
- OPENQUERYでのSELECT...WHERE句がなんか変
- SELECT * FROM TBL WHERE '2012-01-01' < COL ならうまくヒットするのに、SELECT * FROM TBL WHERE COL > '2012-01-01' だとヒットしない場合があります(不等号の向きが小なりのみ使えるのかな?)でも、大丈夫なときは大なり記号を使ってもうまくいきます。詳細調査中...
- SQLの実行プランを取得できる?
- 「ODBC データソース アドミニストレータ」を開くと、「トレース」と書かれたタブがあり、これを利用できます(公式ドキュメント "The Notes SQL trace utility" より)
- Unable to validate userid ****
- 該当ユーザーについて、Authentication List Manager で、ID登録が完了していない可能性があります。[Add User]で登録したあと、[Save List]ボタンをクリックして登録が完了します。
- Invalid character
- テーブル名、ビュー名、列名などを ""(二重引用符)で囲ってみると、解消されるかもしれません(オブジェクト名の先頭が数字のときに発生しました)
- Incompatible data types in comparison
- WHERE句で、数字リテラルを使った比較をしようとした場合に発生することがあります。数字のつもりのフィールドでも、文字列扱いになっている場合(とくにビューの場合は、すべて文字列型で返されます)があります。自動で変換してくれませんので、自前で数値を文字列に変換しておきます。
- リンク サーバー "******" の OLE DB プロバイダー "MSDASQL" のスキーマまたはカタログの使用は無効です。4 部構成の名前が指定されましたが、このプロバイダーではカタログまたはスキーマを使用するのに必要なインターフェイスが公開されていません。
- 一般的なSELECT文(リンクサーバオブジェクト指定)ではクエリーできず、T-SQLのOPENQUERY関数を使用してアクセスする必要があるようです。すなわち
SELECT * FROM [DOMINOLINK].[default].dbo.TargetView
ではなく
SELECT * FROM OPENQUERY([DOMINOLINK], 'SELECT * FROM TargetView')
と指定します。
テーブル名やビュー名は、SQL Server Management Studio で、リンクサーバー内のカタログを展開したときに表示されるオブジェクト表現に倣います(括弧がアンダースコアに変換されたりしています。(MyView) が _MyView_ であったり)
間違いのご指摘や補足情報、お待ちしています!
参考情報
感謝申し上げます!
- IBM Lotus NotesSQL (IBM Developer Works)
- Connect to Lotus Domino using SQL Server Linked Server
- IBM 技術情報 NotesSQL を利用するためのガイド
- QA@IT SQLserverからNotesのDBを参照したい
- ワルブリックス株式会社 64bit Windowsで 32bitのODBCドライバを使う
- 株式会社ITサポートさくら ODBC/64bit版Windowsで32bit版ODBCの設定を行う方法
- Using the new IBM ODBC Driver for Notes/Domino 9.0 - Mat Newmanさん
- User name and password errors - lotus.com
- Application integration: Create an ODBC connection to a Lotus Notes database - Greg Griffithsさん