JBoss Enterprise Data Services 5 Data Services クライアント開発者

JBoss Enterprise Data Services 5
Data Services クライアント開発者
ガイド
JBoss 開発者向け
エディッション 5.2.0
Landmann
JBoss Enterprise Data Services 5 Data Services クライアント開発者ガ
イド
JBoss 開発者向け
エディッション 5.2.0
Landmann
rlandmann@redhat.co m
法律上の通知
Copyright © 2011 Red Hat, Inc..
T his document is licensed by Red Hat under the Creative Commons Attribution-ShareAlike 3.0 Unported
License. If you distribute this document, or a modified version of it, you must provide attribution to Red
Hat, Inc. and provide a link to the original. If the document is modified, all Red Hat trademarks must be
removed.
Red Hat, as the licensor of this document, waives the right to enforce, and agrees not to assert, Section
4d of CC-BY-SA to the fullest extent permitted by applicable law.
Red Hat, Red Hat Enterprise Linux, the Shadowman logo, JBoss, MetaMatrix, Fedora, the Infinity Logo,
and RHCE are trademarks of Red Hat, Inc., registered in the United States and other countries.
Linux ® is the registered trademark of Linus T orvalds in the United States and other countries.
Java ® is a registered trademark of Oracle and/or its affiliates.
XFS ® is a trademark of Silicon Graphics International Corp. or its subsidiaries in the United States
and/or other countries.
MySQL ® is a registered trademark of MySQL AB in the United States, the European Union and other
countries.
Node.js ® is an official trademark of Joyent. Red Hat Software Collections is not formally related to or
endorsed by the official Joyent Node.js open source or commercial project.
T he OpenStack ® Word Mark and OpenStack Logo are either registered trademarks/service marks or
trademarks/service marks of the OpenStack Foundation, in the United States and other countries and
are used with the OpenStack Foundation's permission. We are not affiliated with, endorsed or
sponsored by the OpenStack Foundation, or the OpenStack community.
All other trademarks are the property of their respective owners.
概要
本書を読んで Data Services の JDBC 拡張を使用してクライアントアプリケーションより仮想データベー
スへアクセスする方法を学びましょう。トランザクションや SSL、Hibernate の統合についても取り上げ
ます。
目次
目次
.はじめに
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4. . . . . . . . . .
1. 本書の表記規則
4
1.1. 書体の表記規則
4
1.2. 引用文の表記規則
5
1.3. 注記および警告
6
2. サポート、およびフィードバックのお願い
6
2.1. サポートが必要ですか?
6
2.2. フィードバックをお願いします
7
. . .1章
第
. . . .Data
. . . . . Services
. . . . . . . . . .サーバーへの接続
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .8. . . . . . . . . .
1.1. ドライバークラスを使用した接続
8
1.1.1. URL 形式
9
1.1.2. URL 接続プロパティー
10
1.2. データソースクラスを使用した接続
12
1.2.1. Data Services の DataSource 接続プロパティー
13
1.3. JBoss AS データソース
14
1.3.1. DataSource 接続
15
1.3.2. ドライバーベースの接続
15
1.3.3. ローカル JDBC 接続
15
1.4. 複数ホストの使用
16
1.4.1. フェイルオーバー
17
1.4.2. ロードバランシング
17
1.4.3. 詳細設定
18
1.4.4. 再認証
18
. . .2章
第
. . . .準備済みステートメント
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
............
. . .3章
第
. . . JDBC
. . . . . . .API
. . . .への
. . . . .Data
. . . . . Services
. . . . . . . . . .の拡張
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
............
3.1. ステートメントの拡張
20
3.2. 実行プロパティー
20
3.3. SET ステートメント
21
3.4. SHOW ステートメント
22
3.5. トランザクションステートメント
23
3.6. 部分結果モード
23
3.7. XML 拡張
24
3.7.1. ドキュメントのフォーマット
24
3.7.2. スキーマ検証
25
. . .4.章
第
. . .JDBC
. . . . . . でのトランザクション
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
............
4.1. ローカルトランザクション
26
4.1.1. ローカルトランザクションの無効化
26
4.2. 要求レベルトランザクション
27
4.2.1. 複数挿入バッチ
28
4.3. グローバルトランザクションの使用
28
4.4. 制限
29
4.4.1. アプリケーションの制限
29
4.4.2. エンタープライズ情報システムサポート
30
. . .5章
第
. . . .SSL
. . . . クライアント接続
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .31
...........
5.1. デフォルトのセキュリティー
31
5.2. SSL モデル
31
5.3. クライアントの SSL 設定
32
5.3.1. オプション 1: Java SSL プロパティー
32
1
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
5.3.2. オプション 2: Deta Services 固有のプロパティー
32
. . .6章
第
. . . .Data
. . . . . Services
. . . . . . . . . .を
. . Hibernate
. . . . . . . . . . .と使用する
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .35
...........
6.1. 制限
35
6.2. 設定
35
. . .7章
第
. . . .ODBC
. . . . . . .サポート
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .37
...........
7.1. ODBC ドライバークライアントのインストール
37
7.1.1. Red Hat Enterprise Linux やその他の UNIX オペレーティングシステムに ODBC ドライバー
をインストールする
37
7.1.2. Microsoft Windows に ODBC ドライバーをインストールする
38
.サポート対象外の
. . . . . . . . . . . . . . . . . JDBC
. . . . . . .メソッド
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4. .2. . . . . . . . . .
A.1. ResultSet の制限
42
A.2. java.sql のサポート対象外のクラスおよびメソッド
42
A.3. javax.sql のサポート対象外のクラスおよびメソッド
47
.Keytool
. . . . . . . .を用いた自己署名証明書の生成
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4. .8. . . . . . . . . .
B.1. 秘密鍵と公開鍵のペアの作成
48
B.2. 公開鍵の抽出
48
B.3. トラストストアの作成
48
. . . . . .Lesser
GNU
. . . . . . . General
. . . . . . . . .Public
. . . . . . .License
. . . . . . . . 2.1
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
............
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
改訂履歴
............
2
目次
3
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
はじめに
1. 本 書 の 表 記 規 則
本ガイドでは、一部の単語や語句を強調して、特定の情報に対する読者の注意を促すために、以下のよう
な表記規則を採用しています。
本ガイドの PDF および紙書籍版では、Liberation フォントセットの書体を使用しています。また、
Liberation フォントセットがご使用のシステムにインストールされている場合には、HT ML 版もこの書体
で表示されます。インストールされていない場合には、別の対応する書体で表示されます。なお、Red
Hat Enterprise Linux 5 以降のバージョンでは、Liberation フォントセットがデフォルトでインストールさ
れる点に注意してください。
1.1. 書体の表記規則
本ガイドでは、特定の単語や語句に対する注意を促すために、4 つの書体表記規則を採用しています。こ
れらの表記規則および適用される状況は、以下のとおりです。
太字の等幅フォント
シェルコマンド、ファイル名、パスなど、システムへの入力を強調するために使用します。また、キー名
やキーの組み合わせを強調するのにも使用します。以下が例となります。
作業ディレクトリ内の m y_next_bestselling_novel というファイルの内容を表示する
には、シェルプロンプトで cat m y_next_bestselling_novel というコマンドを入力し
て Enter キーを押し、そのコマンドを実行します。
上記の例には、ファイル名、シェルコマンド、キー名が含まれており、すべて太字の等幅フォントで表示
されていますが、文脈で区別することができます。
キーの組み合わせは、プラス記号 (+) で各キーがつながれているので、個別のキーと区別することができ
ます。以下が例となります。
Enter を押してコマンドを実行します。
Ctrl+Alt+F2 を押して仮想ターミナルに切り替えます。
第 1 の例では、押すべき特定のキー名が強調されています。第 2 の例では、3 つのキーを同時に押す、
キーの組み合わせが強調されています。
ソースコードを記載する場合、その段落で言及されるクラス名、メソッド、関数、変数名、戻り値は上記
のように 太字の等幅フォント で表示されます。以下が例となります。
ファイル関連のクラスには、filesystem (ファイルシステム)、file (ファイル)、dir
(ディレクトリ) などがあります。各クラスにそれぞれ独自のパーミッションセットが関連付
けられています。
太字の可変幅フォント
この書体は、アプリケーション名、ダイアログボックスのテキスト、ラベル付きボタン、チェックボック
ス/ラジオボタンのラベル、メニュータイトル、サブメニュータイトルなど、システムで表示される単語や
語句であることを示します。以下が例となります。
メインメニューバーから システム → 設定 → マウス の順で選択し、マウスの設定 を起動
します。全般 タブで 左利き のラジオボタンを選択して 閉じる をクリックし、マウスの主
4
はじめに
ボタンを左から右へ切り替えます (左利きのユーザーが使用するのに適切な設定に変更しま
す)。
gedit ファイルに特殊文字を入力するには、メインのメニューバーから アプリケーション
→ アクセサリ → 文字マップ の順に選択します。次に 文字マップ のメニューバーから 検
索 → 検索 … の順に選択して 検索 フィールドに文字名を入力し、次を検索 をクリックしま
す。検索対象の文字が 文字テーブル に強調表示されます。その文字をダブルクリックして
コピーする文字列 のフィールドに表示されたら、コピー ボタンをクリックします。この後
に編集中のドキュメントに戻り、gedit のメニューバーから 編集 → 貼り付け の順で選択し
ます。
上記のテキストには、アプリケーション名、システム全体のメニュー名と項目、アプリケーション固有の
メニュー名、GUI インターフェースで使用されているボタンおよびテキストが含まれており、これらはす
べて、太字の可変幅フォントで表示されていますが、文脈で区別することができます。
太字斜体の等幅フォント または 太字斜体の可変幅フォント
太字の等幅フォントおよび太字の可変幅フォントに斜体を使用した場合には、いずれも置き換え可能な可
変テキストであることを意味します。斜体は、記載されている通りには入力しないテキスト、あるいは状
況によって変化するテキストを示します。以下が例となります。
ssh を使用してリモートマシンに接続するには、シェルプロンプトで ssh
username@ domain.name と入力します。リモートマシンが exam ple.com で、そのマシン
上のユーザー名が john である場合には、ssh john@ exam ple.com と入力してください。
m ount -o rem ount file-system のコマンドは、指定したファイルシステムを再マウン
トします。たとえば、/hom e ファイルシステムを再マウントするコマンドは m ount -o
rem ount /hom e となります。
現在インストール済みのパッケージのバージョンを確認するには、rpm -q package のコマ
ンドを使用します。その結果、次のような出力が返されます: package-version-release
ユーザー名、ドメイン名、ファイルシステム、パッケージ、バージョン、およびリリースが太字のイタ
リック体で表示されている点に注意してください。これらの語句はプレースホルダーで、コマンドを発行
する際に入力するテキストまたはシステムによって表示されるテキストのいずれかです。
斜体は、著作物のタイトルを表すという標準的な用途の他に、重要な用語の初出時にも使用されます。以
下が例となります。
Publican は DocBook の出版システムです。
1.2. 引用文の表記規則
端末の出力とソースコードは、周囲のテキストとは視覚的に区切られて表示されます。
端末に送信される出力は、ローマン体の等幅フォント を使用して以下のように表示されます。
books
books_tests
Desktop
Desktop1
documentation
downloads
drafts
images
mss
notes
photos
scripts
stuff
svgs
svn
ソースコードの表示にも ローマン体の等幅フォント が使用されますが、以下のような構文強調表示が追
加されます。
5
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
package org.jboss.book.jca.ex1;
import javax.naming.InitialContext;
public class ExClient
{
public static void main(String args[])
throws Exception
{
InitialContext iniCtx = new InitialContext();
Object
ref
= iniCtx.lookup("EchoBean");
EchoHome
home
= (EchoHome) ref;
Echo
echo
= home.create();
System.out.println("Created Echo");
System.out.println("Echo.echo('Hello') = " + echo.echo("Hello"));
}
}
1.3. 注記および警告
本ガイドでは、見落としがちな情報に注意を促すために、次にあげる 3 つの視覚的スタイルを使用してい
ます。
注記
注記には、対象のタスクに関するヒント、ショートカット、その他のアプローチなどを記載してい
ます。注記を無視しても、悪影響はありませんが、作業を効率的に行うためのコツを見逃してしま
う可能性があります。
重要
重要の欄には、現行セッションのみに適用される設定の変更や、更新を適用するのに再起動が必要
なサービスなど、見落としがちな情報を記載しています。「重要」と記載された事項を無視して
も、データ損失などには至りませんが、作業が思ったようにスムーズに進まなくなる可能性があり
ます。
警告
警告は、無視しないでください。警告を無視すると、データ損失が発生する可能性が非常に高くな
ります。
2. サ ポ ー ト 、 お よ び フ ィ ー ド バ ッ ク の お 願 い
2.1. サポートが必要ですか?
本書に説明してある手順で問題があれば、Red Hat カスタマーポータル(http://access.redhat.com)をご覧
ください。カスタマーポータルでは以下を行うことができます。
6
はじめに
Red Hat 製品に関する技術的なサポートの記載をナレッジベースで検索、閲覧することができます。
サポートケースを Red Hat グローバルサポートサービス(GSS)に提出することができます。
他の製品文書を参照することができます。
また、Red Hat は Red Hat のソフトウェアやテクノロジーに関するディスカッションの場として多くの
メーリングリストを設置しています。公開されているメーリングリストについて
はhttps://www.redhat.com/mailman/listinfoで一覧を参照してください。メーリングリストをサブスクライ
ブする、またはメーリングリストのアーカイブを参照する場合はそのメーリングリスト名をクリックしま
す。
2.2. フィードバックをお願いします
誤植、本ガイドの改善案がある場合、ご意見お待ちしております。製品JBoss Enterprise SOA
Platform 、コンポーネントdoc-Data_Services_Client_Developer_GuideとしBugzilla から報
告してください。以下のリンクhttp://bugzilla.redhat.com/から、あらかじめ記入が施されている本製品の
バグレポートへ移動できます。
Bugzilla のDescription フィールドにある以下のテンプレートに記載してください。できるだけ具体的
に問題を説明していただけると、迅速に問題解決へ向けた取り組みが行いやすくなります。
文書URL:
項、項のタイトル:
問題の説明:
改善案:
追加情報:
問題報告の功績が認められるよう、名前を記載するのを忘れないようにしてください 。
7
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
第 1章 Data Services サーバーへの接続
本章では Java Database Connectivity API (JDBC) を使用して Data Services の仮想データベースへ接続
する異なるメソッドについて説明します。ここでは JDBC の基本知識が必要となります。JDBC を使用し
たことがない場合は http://download.oracle.com/javase/tutorial/jdbc/index.html の Java JDBC ドキュメン
トを参照してください。
Data Services の JDBC API は Data Services サーバーにデプロイされたすべての仮想データベース
(VDB) への JDBC によるアクセスを提供します。クライアントアプリケーションは Data Services サー
バーに接続し、Data Services の JDBC API を使用してデプロイされた VDB に対して SQL クエリを発行
することができます。標準の JDBC API クラスを使用してメタデータへ問い合わせをしたり、クエリを実
行することもできます。
Data Services の VDB へ JDBC 接続を作成する以下の 3 つの方法について説明します。
1. org.teiid.jdbc.T eiidDriver ドライバークラスを使用
2. org.teiid.jdbc.T eiidDatasource データソースクラスを使用
3. デプロイされた JBoss データソースを使用
Data Services の VDB に接続する際、次の点を考慮する必要があります。
1. Data Services クライアント JAR — teiid-client.jar — は Data Services VDB に接続してい
るクライアントアプリケーションのクラスパス上に存在する必要があります。 この JAR ファイル
は Data Services サーバーの jbossas/server/PROFILE/lib ディレクトリにあり、JDBC を使
用して Data Services VDB に接続するためのクラスが含まれています。
2. Data Services JDBC API は JDBC 4.0 の仕様と互換性がありますが、すべてのメソッドを完全サ
ポートしているわけではありません。更新可能な結果セットや SQL3 データタイプなどの上級機能
もサポートされません。
サポート対象外のメソッドの詳細は 付録A サポート対象外の JDBC メソッド を参照してくださ
い。
3. Data Services VDB に接続しているクライアントアプリケーションは Java 1.6 JDK が必要になりま
す。Java の以前のバージョンはサポートされません。
4. Data Services サーバーに接続する前に以下の点について確認してください。
a. Data Services サーバーがインストールされ、稼働している。
b. アプリケーションが接続しようとしている仮想データベース (VDB) はデプロイされている。
手順はスタートガイドと Data Services 管理者ガイド を参照してください。
1.1. ド ラ イ バ ー ク ラ ス を 使 用 し た 接 続
Java の java.sql.DriverManager クラスを使用して接続を作成する場合に使用するドライバークラ
スは org.teiid.jdbc.T eiidDriver になります。
完全な例は eds/teiid/exam ples/sim pleclient/ ディレクトリに含まれているソースコードを参
照してください。
手順 1.1 ドライバークラスによる接続の作成
1. Data Services クライアント JAR がクラスパス上に存在するようにする
クライアントアプリケーションでは Data Services クライアント JAR がクラスパス上に存在しなけ
ればなりません。アプリケーションが Data Services がインストールされているアプリケーション
サーバーで稼働しているウェブアプリケーションである場合、Data Services クライアント JAR は
既にクラスパス上に存在しますが、それ以外の場合は Data Services クライアント JAR — teiid-
8
第1章 D ata Services サーバーへの接続
client.jar — をクライアントアプリケーションのクラスパス上に追加する必要がありま
す。teiid-client.jar は Data Services サーバーの jbossas/server/PROFILE/lib ディレ
クトリにあります。
2. 接続オブジェクトの作成
DriverManager.getConnection() メソッドを使用して接続オブジェクトを作成します。
例 1.1 ドライバー接続の作成
public class TeiidClient
{
public Connection getConnection(String user, String password) throws
Exception
{
String url =
"jdbc:teiid:myVDB@mm://localhost:31000;ApplicationName=myApp";
return DriverManager.getConnection(url, user, password);
}
}
接続 URL の形式は 「URL 形式」 を参照してください。
URL 接続プロパティーの一覧は 「URL 接続プロパティー」 を参照してください。
1.1.1. URL 形式
JDBC 接続に次の URL 形式を使用します:
jdbc:teiid:VDB-NAME@mm[s]://HOSTNAME:PORT;[prop-name=prop-value;]*
VDB-NAME
接続している VDB の名前です。VDB 名の中にバージョン情報を含めることもできます。例えば
m yvdb.2 の場合、下記で定義されている version=2 接続プロパティーを提供することと同等
になります。ただし、この形式の VDB 名と version プロパティーを同時に使用することはで
きません。
mm[s]
Data Services の JDBC プロトコルです。m m は通常接続のデフォルトになります。m m s は
adminAPI ツールのデフォルトで、暗号化に SSL を使用します。Data Services で SSL を使用す
る場合の詳細は 5章SSL クライアント接続 を参照してください。
HOST NAME
Data Services サーバーがインストールされているサーバーです。
PORT
Data Services サーバーが着信 JDBC 接続をリッスンするポートです。
[prop-name=prop-value]
セミコロン (;) で区切った追加の名前/値ペアを提供することもできます。? や =、; などの予約
文字が含まれる場合、プロパティー値を URL エンコードしなければなりません。
9
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
サポート対象の URL プロパティーの完全リストは 「URL 接続プロパティー」 を参照してくださ
い。
1.1.2. URL 接続プロパティー
次の表は、Data Services JDBC ドライバーの URL 接続文字列や Data Services の JDBC データソースク
ラスと使用できるサポート対象の接続プロパティーをすべて表しています。
10
第1章 D ata Services サーバーへの接続
表 1.1 接続プロパティー
プロパティー名
タイプ
詳細
ansiQuotedIdentifiers
boolean
SQL の二重引用符で囲まれたエントリーの解析動作
を設定します。デフォルトは true で、二重引用符で
囲まれたエントリーを識別子として解析します。
false に設定すると、有効な文字列リテラルである二
重引用符で囲まれたエントリーは文字列リテラルとし
て解析されます。
ApplicationNam e
String
クライアントアプリケーションの名前です。管理者が
接続を識別できるようにします。
autoCom m itT xn
String
autoCommit が true に設定されている場合のみ適用さ
れます。データの整合性を維持するため、実行された
コマンドをどのように Data Services 内でトランザク
ションとしてラップする必要があるかを判断します。
ON - 常にコマンドを分散トランザクションでラッ
プする
OFF - コマンドを分散トランザクションでラップ
しない
DET ECT (デフォルト) - 実行されたコマンドが 2
つ以上のソースにまたがる場合に自動的に分散ト
ランザクションを使用する
詳細は 4章JDBC でのトランザクション を参照してく
ださい。
autoFailover
boolean
true の場合、コミュニケーションの例外の後に新しい
サーバーインスタンスを自動的に選択します。デフォ
ルトは false です。接続が管理されている場合は接続
をプールよりパージできるため、通常この機能は必要
ではありません。
disableLocalT xn
boolean
true の場合、autoCommit 設定では ローカルトランザ
クションのコミットとロールバックが無視されます。
デフォルトは false です。
FetchSize
int
結果セットのサイズです。デフォルトのサイズは
500 です。<=0 はデフォルトを使用する必要がある
ことを表します。
NoExec
String
(通常、接続プロパティーとして設定されません) ON
または OFF を設定できます。ON の場合、クエリが
実行されないようにしますが、解析やプランニングは
発生します。デフォルトは OFF です。
partialResultsMode
boolean
部分的な結果モードを有効または無効にします。詳細
は 「部分結果モード」 を参照してください。
PassthroughAuthentication
boolean
「ローカル」接続のみに適用されます。このオプショ
ンが true に設定されると、Data Services は呼び出し
スレッド上で既に認証されたセキュリティーコンテキ
ストを検索します。認証されたセキュリティーコンテ
キストが検出された場合、そのユーザーの認証情報を
使用してセッションを作成します。また Data
Services は接続の寿命期間の間、同じユーザーが接
続を使用していることを検証します。呼び出しスレッ
ド上で異なるセキュリティーコンテキストが検出され
11
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
ると、新しいユーザーが Data Services へログインで
きる場合は接続のアイデンティティーを切り替えま
す。ログインできない場合、接続の実行に失敗しま
す。
useCallingT hread
boolean
「ローカル」接続のみに適用されます。このオプショ
ンが true (デフォルト) に設定されると、クエリの処
理に呼び出しスレッドが使用されます。 false の場合
はエンジンスレッドが使用されます。
QueryT im eout
integer
デフォルトのクエリタイムアウト (秒単位) になりま
す。>= 0 である必要があります。0 はタイムアウト
がないことを表しま
す。Statem ent.setQueryT im eout によって上書
きすることが可能です。デフォルトは 0 です。
useJDBC4 Colum nNam eAndLab
elSem antics
boolean
JDBC4 の変更により、エイリアスのない列名を
ResultSetMetadata 列名として返すようになりまし
た。以前は、列の別名が使用されると列名として返さ
れました。このプロパティーを false に設定すると、
JDBC3 やそれ以前 JDBC に対するサポートが必要な
時に後方互換性を有効にします。デフォルトは true
です。
Password
String
ユーザーの認証情報
resultSetCacheMode
boolean
結果セットキャッシングを有効または無効にします。
デフォルトは false です。
SHOWPLAN
String
(通常、接続プロパティーとして設定されません)
ON|OFF|DEBUG を設定できます。ON の場合、 結果
と共にクエリプランを返します。DEBUG の場合、さ
らにクエリプランナーのデバッグ情報をログに出力
し、結果と共に返します。プランとログは JDBC の
API 拡張より入手可能です。デフォルトは OFF で
す。
user
String
ユーザー名
version
integer
VDB のバージョン番号
1.2. デ ー タ ソ ー ス ク ラ ス を 使 用 し た 接 続
org.teiid.jdbc.T eiidDatasource クラスは javax.sql.DataSource ベースの接続ファクトリ
です。これを使用して JDBC DataSource 接続や XADataSource 接続を作成することができます。このク
ラスを使用して管理された接続や XA 接続を作成します。Data Services は XA プロトコルをサポートし、
XA をサポートする Data Services のソースへ XA トランザクションが拡張されます。
また、Data Services の DataSource クラスはシリアライズ可能で、JNDI ネーミングサービスと併用する
ことができます。
完全な例は eds/teiid/exam ples/sim pleclient/ ディレクトリに含まれているソースコードを参
照してください。
手順 1.2 T eiidDatasource クラスを使用した接続の作成
1. Data Services クライアント JAR がクラスパス上に存在するようにする
クライアントアプリケーションでは Data Services クライアント JAR がクラスパス上に存在しなけ
12
第1章 D ata Services サーバーへの接続
ればなりません。アプリケーションが Data Services がインストールされているアプリケーション
サーバーで稼働しているウェブアプリケーションである場合、Data Services クライアント JAR は
既にクラスパス上に存在しますが、それ以外の場合は Data Services クライアント JAR — teiidclient.jar — をクライアントアプリケーションのクラスパス上に追加する必要がありま
す。teiid-client.jar は Data Services サーバーの jbossas/server/PROFILE/lib ディレ
クトリにあります。
2. 接続オブジェクトの作成
org.teiid.jdbc.T eiidDataSource オブジェクトを作成するには、必要なプロパティーを設
定し、T eiidDataSource.getConnection() メソッドを使用して接続オブジェクトを取得し
ます。
例 1.2 ドライバー接続の作成
public class TeiidClient
{
public Connection getConnection(String user, String password) throws
Exception
{
TeiidDataSource ds = new TeiidDataSource();
ds.setUser(user);
ds.setPassword(password);
ds.setServerName("localhost");
ds.setPortNumber(31000);
ds.setDatabaseName("myVDB");
return ds.getConnection();
}
}
接続プロパティーの完全一覧は 「Data Services の DataSource 接続プロパティー」 を参照してくださ
い。
1.2.1. Data Services の DataSource 接続プロパティー
version 以外の 「URL 接続プロパティー」 に記載されている URL 接続プロパティー
は、org.teiid.jdbc.T eiidDataSource に対応する「セットメソッド」を持っていま
す。version は T eiidDataSource で DatabaseVersion として参照されます。
URL より想定されるプロパティーは、 表1.2「Datasource プロパティー」 の通り追加のセットメソッド
を持っています。
13
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
表 1.2 Datasource プロパティー
プロパティー名
タイプ
詳細
AlternateServers
String
「ホスト:ポート」 エントリーのオプションの区切りリス
トです。詳細は 「複数ホストの使用」 を参照してくだ
さい。
AdditionalProperties
String
接続 URL のプロパティー文字列と同じ形式であるプロパ
ティーのオプション設定です。
DatabaseNam e
String
Data Services にデプロイされた仮想データベース
(VDB) の名前です。任意でデータベース名の中に
DatabaseVersion が含まれるようにすることも可能で
す。例えば、「myvdb.2」は値が 2 に設定された
DatabaseVersion プロパティーを設定することと同じに
なります。しかし、この形式のデータベース名を使用
し、同時に DatabaseVersion プロパティーを使用するこ
とはできません。
DatabaseVersion
integer
VDB バージョン
DataSourceNam e
String
このデータソースに付与された名前
PortNum ber
integer
サーバー処理がリッスンするポート番号。
ServerNam e
String
Data Services ランタイムがインストールされている
サーバーのホスト名。
secure
boolean
安全な接続。クライアントサーバー間で SSL (mms) ベー
スの接続を使用するように示すためのフラグです。
1.3. JBoss AS デ ー タ ソ ー ス
Data Services を JDBC データソースとして設定することができます。設定後、JNDI からデータソースへ
接続したり、Java EE アプリケーションへデータソースを挿入することができます。Deta Services の
データソースは他のデータベースリソースのデータソースと同様にデプロイされます。
接続している T eiid インスタンスが JBoss AS インスタンスと同じ VM に存在する場合は特例となりま
す。ご使用のデプロイメントがこれに該当する場合は 「ローカル JDBC 接続」 の指示に従ってくださ
い。
手順 1.3 Data Services データソースのデプロイ
1. 必要な場合は Data Services のクライアントライブラリをデプロイする
データソースをデプロイするアプリケーションサーバーが Data Services が稼働しているアプリ
ケーションサーバーインスタンスと同じでない場合、Data Services のクライアント JAR をインス
トールする必要があります。インストールするには、Data Services のクライアント JAR ファイル
teiid-client.jar を PROFILE/lib/ ディレクトリへコピーします。
Data Services クライアント JAR ファイルは Data Services サーバーの PROFILE/lib/ ディレク
トリにあります。
2. データソースファイルを作成する
データソースファイルはデータソースの設定が含まれる XML ファイルです。命名規則は
DATASOURCE-NAME-ds.xm l となり、DATASOURCE-NAME をデータソースの論理名に置き換えま
す。
下記の通り、ファイルの内容はデプロイメントのタイプ (XADatasource、 Driver、Local) によって
異なります。
14
第1章 D ata Services サーバーへの接続
3. データソースファイルのデプロイ
サーバーの PROFILE/deploy/ ディレクトリへファイルをコピーしてデータソースをデプロイしま
す。
* -ds.xm l ファイルに指定されている JNDI 名を使用してデータソースにアクセスできるようになりま
す。
1.3.1. DataSource 接続
デプロイメント環境に固有する正しい DatabaseName、ServerName、ポート番号、認証情報を把握する
ようにしてください。
例 1.3 Data Services の DataSource クラスを使用する XADataSource
<datasources>
<xa-datasource>
<jndi-name>TEIID-DS</jndi-name>
<xa-datasource-class>org.teiid.jdbc.TeiidDataSource</xa-datasource-class>
<xa-datasource-property name="DatabaseName">myVDB</xa-datasource-property>
<xa-datasource-property name="serverName">localhost</xa-datasourceproperty>
<xa-datasource-property name="portNumber">31000</xa-datasource-property>
<xa-datasource-property name="user">admin</xa-datasource-property>
<xa-datasource-property name="password">password</xa-datasource-property>
<!-- pool and other JBoss datasource properties -->
<check-valid-connection-sql>SELECT 1</check-valid-connection-sql>
<min-pool-size>5</min-pool-size>
<max-pool-size>10</max-pool-size>
</xa-datasource>
</datasources>
1.3.2. ドライバーベースの接続
Data Services の JDBC ドライバークラス org.teiid.jdbc.T eiidDriver を使用してデータソース
を作成することもできます。
<datasources>
<local-tx-datasource>
<jndi-name>TEIID-DS</jndi-name>
<connection-url>jdbc:teiid:myVDB@mm://localhost:31000</connection-url>
<driver-class>org.teiid.jdbc.TeiidDriver</driver-class>
<user-name>admin</user-name>
<password>teiid</password>
<!-- pool and other JBoss datasource properties -->
<check-valid-connection-sql>SELECT 1</check-valid-connection-sql>
<min-pool-size>5</min-pool-size>
<max-pool-size>10</max-pool-size>
</local-tx-datasource>
</datasources>
1.3.3. ローカル JDBC 接続
15
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
T eiid ランタイムがインストールされている JBoss AS インスタンスにクライアントアプリケーションを
デプロイする場合、ソケットベースの JDBC 接続を用いずに接続する方法があります。JDBC API が同じ
VM でローカル T eiid ランタイムをルックアップする「ローカル」接続を確立するには若干変更された
データソースを使用します。
警告
DataSource は T eiid の VDB がデプロイされる前に起動するため、ローカル接続の最小プールサイ
ズをデフォルトの 0 のままにしておきます。最小プールサイズを変更すると、T eiid DataSource
の起動時にエラーが発生します。
注記
デフォルトでは、ローカル接続は呼び出しスレッドを使用して処理操作を実行するため、呼び出し
スレッドのブロック中にエンジンスレッドを使用しません。この動作を無効にするには、接続プロ
パティー useCallingT hreads=false を設定します。
例 1.4 ローカルデータソース
<datasources>
<xa-datasource>
<jndi-name>TEIID-DS</jndi-name>
<xa-datasource-class>org.teiid.jdbc.TeiidDataSource</xa-datasource-class>
<xa-datasource-property name="DatabaseName">myVDB</xa-datasource-property>
<xa-datasource-property name="user">admin</xa-datasource-property>
<xa-datasource-property name="password">password</xa-datasource-property>
<!-- pool and other JBoss datasource properties -->
<max-pool-size>10</max-pool-size>
</xa-datasource>
</datasources>
1.4. 複 数 ホ ス ト の 使 用
フェイルオーバー機能とロードバランシング機能を使用すると、同じクラスターの複数の Data Services
サーバーへ接続することができます。
これらの機能を有効にするには、クライアントが複数のホスト名とポート番号の組み合わせを
host:port のコンマ区切りリストとして URL 接続文字列に指定するのが最も簡単な方法となります。
例 1.5 URL 接続文字列の例
jdbc:teiid:<vdb-name>@mm://host1:31000,host1:31001,host2:31000;version=2
DataSource を使用して Data Services サーバーに接続する場合、AlternateServers プロパティーま
たはメソッドを使用してフェイルオーバーサーバーを定義することができます。この形式も host:port
16
第1章 D ata Services サーバーへの接続
のコンマ区切りリストになります。
クライアントはリストより Data Services サーバーの 1 つを無作為に選択し、そのサーバーとのセッショ
ンを確立します。そのサーバーへ接触できない場合、無作為順に残りの各サーバーへ接続しようとしま
す。これにより、接続時間のフェイルオーバーと無作為サーバー選択のロードバランシングの両方を可能
にします。
1.4.1. フェイルオーバー
管理接続 (AdminShell によって使用される接続など) が使用される場合や、autoFailover 接続プロパ
ティーが true に設定されている場合、接続後のフェイルオーバーが使用されます。接続前のフェイルオー
バーではほぼ毎秒ごとに ping を送信し、使用前に接続をテストします。ping に失敗すると、操作を実行
する前に新しいインスタンスが選択されます。
この場合、クライアントはトランザクションやクエリを再起動せず、セッションスコープが指定された一
時テーブルも再作成しないため、本当の「透過的なアプリケーションフェイルオーバー」とはみなされま
せん。非管理接続と併用する場合は細心の注意を払ってください。
1.4.2. ロードバランシング
接続後のロードバランシングは 2 通りに使用できます。1 つ目は、T eiidDataSource を使用し、Data
Services の PooledConnections によって返された接続の close メソッドが呼び出された場合、新し
いサーバーインスタンスが自動的に選択されます。しかし、ドライバーベースの接続を使用したり、接続
プールで T eiidDataSource を使用する場合、ロードバランシングは自動的に発生しません。2 つ目
は、set ステートメント SET NEWINST ANCE T RUE を使用して明示的にロードバランシングを誘発する
ことができます。通常、このステートメントを手作業で発行する必要はありませんが、DataSource 設定
の接続テストクエリとして使用します。
例 1.6 接続後にロードバランシングを使用する JBoss AS DataSource
<datasources>
<local-tx-datasource>
<jndi-name>TEIID-DS</jndi-name>
<connection-url>
jdbc:teiid:myVDB@mm://localhost:31000,mm://localhost:32000
</connection-url>
<driver-class>org.teiid.jdbc.TeiidDriver</driver-class>
<user-name>admin</user-name>
<password>teiid</password>
<!-- pool and other JBoss datasource properties -->
<check-valid-connection-sql>SET NEWINSTANCE TRUE</check-valid-connectionsql>
<min-pool-size>5</min-pool-size>
<max-pool-size>10</max-pool-size>
</local-tx-datasource>
</datasources>
Data Services は再使用される追加のソケット接続のプールを維持します。ロードバランシングでは接続
を別のサーバーインスタンスに切り替える潜在的なコストを削減できます。デフォルト設定では 16 の接
続を維持します。これはクライアント jar の teiid-client-settings.properties ファイルにある
org.teiid.sockets.m axCachedInstances プロパティーによって設定されます。クライアントア
プリケーションが大量の Data Services インスタンスへ接続し、接続後にロードバランシングが使用され
る場合、キャッシュ済みインスタンスの数を増やすよう考慮してください。設定するに
は、org.teiid.sockets.m axCachedInstances システムプロパティーを作成して必要値を設定す
17
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
るか、新規の teiid-client-settings.properties ファイルを作成してクライアント jar ファイル
の前になるようクラスパスに挿入します。
重要
現在トランザクションを実行しているセッションレベル一時テーブル、セッションレベルのキャッ
シュエントリー、指定セッションの PreparedPlans は他のクラスターのメンバーは使用できませ
ん。そのため、論理接続が閉じられ、実際の接続が再使用された時のみロードバランシングを接続
後に使用することが推奨されます。これは典型的な接続プールのパターンになります。
1.4.3. 詳細設定
サーバーディスカバリー、ロードバランシング、フェイルオーバー、再トライ、再トライの遅延などはデ
フォルトのポリシーが適切でない場合にカスタマイズすることができます。カスタマイズを行う前に
org.teiid.net.socket.ServerDiscovery インターフェースとデフォルト実装の
org.teiid.net.socket.UrlServerDiscovery を参照してください。
UrlServerDiscovery 実装は次を提供します。
URL ホストからのサーバーディスカバリー (DataSource サーバー/alternativeServers)
ロードバランシングやフェイルオーバーの無作為選択
ホストごとに 1 つの接続を試行
バイアスなし
ブラックリスト
その他の上級機能
フォールバックストラテジーとして使用し、必要な changed メソッドのみを実装できるようにするた
め、通常は UrlServerDiscovery を拡張します。接続ごとに 1 つの ServerDiscovery インスタン
スが作成されることを考慮することが重要となります。インスタンス間での情報共有は、静的ステートま
たはその他の共有ルックアップより行います。
カスタマイズしたサーバーディスカバリークラスは、完全なクラス名を使用して discoveryStategy 接続ま
たは DataSource プロパティーによって参照されなければなりません。
haproxy などの外部 tcp ロードバランサーの使用を選択することもできます。通常、ロードバランサーの
単一ホスト/ポートのみを使用するよう T eiid ドライバーや DataSource を設定します。
1.4.4. 再認証
T eiid 接続 (org.teiid.jdbc.T eiidConnection インターフェースによって定義される) は
changeUser メソッドによる接続の再認証をサポートしています。 再認証に成功すると、指定のアイデン
ティティーを用いて現在の接続が使用されます。既存のステートメント/結果セットも以前のアイデンティ
ティーで使用可能です。
18
第2章 準備済みステートメント
第 2章 準備済みステートメント
Data Services は java.sql.PreparedStatem ent の標準実装を提供します。準備されたステートメ
ントによって、サーバーがステートメントの解析や解決、プランニングをスキップできるため、共通ス
テートメントの実行を迅速化するために大変重要です。
準備済みステートメントを使用する際、次の点を考慮してください。
Data Services がサーバー側でプランキャッシングを実行するため、クライアント側の Data Services
PreparedStatem ents をプールする必要はありません。
キャッシュ済みプランの数は設定可能です。プランは LRU の順 (最後に使用されてから未使用の期間
が長い順) にパージされます。
キャッシュ済みプランはクラスターによって分散されません。クラスターメンバーごとに新しいプラ
ンを作成する必要があります。
プランは VDB 全体または特定セッションに対してキャッシュされます。プランの範囲は、プランイン
グ処理中に評価された関数に基づき自動的に検出されます。
現在、コスト情報のランタイム更新は再プランニングを実行しません。現時点ではセッションスコー
プが指定された一時テーブルや内部実体化されたテーブルのみがコスト情報を更新します。
CallableStatem ent より実行される保存されたプロシージャーのプランは
PreparedStatem ent と同様にキャッシュされます。
関数の署名が 1 つのみである場合や戻り値の型が判断される述語で関数が使用された場合、関数署名
のバインド変数タイプ (例: where t.col = abs(?)) を判断することができます。さらに複雑な状
況では、upper(convert(?, string)) のように cast や convert を使用してヒントを追加する必
要がある場合があります。
PreparedStatem ent の使用に関する詳細は
http://download.oracle.com/javase/6/docs/technotes/guides/jdbc/getstart/preparedstatement.html の Java
ドキュメントを参照してください。
19
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
第 3章 JDBC API への Data Services の拡張
3.1. ス テ ー ト メ ン ト の 拡 張
Data Services のステートメント拡張インターフェース org.teiid.jdbc.T eiidStatem ent は JDBC
の標準を越えた機能を提供します。この拡張インターフェースを使用するには、接続によって返されたス
テートメントをキャストまたはアンラップします。拡張インターフェース上で次のメソッドが提供されま
す。
表 3.1 接続プロパティー
メソッド名
詳細
getAnnotations
ステートメントが最後に SHOWPLAN ON|DEBUG で実行された場
合、クエリエンジンアノテーションを取得します。各
org.teiid.client.plan.Annotation には説明やカテゴ
リー、深刻度が含まれ、クエリプランナーによる選択を理解するた
めに使用されるクエリプランニング中に記録されたノートの解決が
含まれることもあります。
getDebugLog
ステートメントが最後に SHOWPLAN DEBUG で実行された場合、
デバッグログを取得します。
getExecutionProperty
ステートメントオブジェクト上に存在する実行プロパティーの現在
の値を取得します。
getPlanDescription
ステートメントが最後に SHOWPLAN ON|DEBUG で実行された場
合、クエリプランの詳細を取得します。プランは
org.teiid.client.plan.PlanNode オブジェクトで構成され
たツリーです。 通常、プランをテキスト形式に変換するために
PlanNode.toString() または PlanNode.toXm l() が使用され
ます。
getRequestIdentifier
このステートメント上で最後に実行されたコマンドの識別子を取得
します。コマンドが実行されていない場合は null が返されます。
setExecutionProperty
このステートメントの実行プロパティーを設定します。詳細は 「実
行プロパティー」 の項を参照してください。実行プロパティーが実
行されたステートメントのみに適用される場合以外は一般的に SET
ステートメントの使用が適切です。詳細は 「SET ステートメント」
を参照してください。
setPayload
トランスレーターに渡すコマンド毎のペイロードを設定します。現
在、ビルトインは Oracle データソースへのヒント送信のみに使用さ
れます。
3.2. 実 行 プ ロ パ テ ィ ー
実行プロパティーはステートメントごとに T eiidStatem ent インターフェースから設定することがで
きます。また、SET ステートメントを使用して接続上で設定することも可能です。プロパティーキーは
org.teiid.jdbc.ExecutionProperties インターフェース上の定数によって定義されます。
詳細は 「ステートメントの拡張」 と 「SET ステートメント」 を参照してください。
20
第3章 JD BC API への D ata Services の拡張
表 3.2 実行プロパティー
プロパティー名 /文字列定数
詳細
PROP_T XN_AUT O_WRAP /
autoCom m itT xn
接続プロパティーと同様。
PROP_PART IAL_RESULT S_MO
DE / partialResultsMode
詳細は 「部分結果モード」 を参照してください。
PROP_XML_FORMAT /
XMLForm at
XML ドキュメントモデルによって返された XML ドキュメントの
フォーマットを決定します。詳細は 「ドキュメントのフォーマッ
ト」 を参照してください。
PROP_XML_VALIDAT ION /
XMLValidation
XML ドキュメントモデルによって返された XML ドキュメントが処理
後にスキーマに対して検証されるかを決定します。詳細はリファレ
ンスガイドの「XML SELECT コマンド」の章と「ドキュメントの検
証」の項を参照してください。
RESULT _SET _CACHE_MODE /
resultSetCacheMode
接続プロパティーと同様。
SQL_OPT ION_SHOWPLAN /
SHOWPLAN
接続プロパティーと同様。
NOEXEC / NOEXEC
接続プロパティーと同様。
JDBC4 COLUMNNAMEANDLABEL
SEMANT ICS /
useJDBC4 Colum nNam eAndLa
belSem antics
接続プロパティーと同様。
3.3. SET ス テ ー ト メ ン ト
SET ステートメントを使用して接続上で実行プロパティーを設定することもできます。現在、SET ス
テートメントは Data Services の言語機能ではなく、JDBC クライアントでのみ処理されます。
SET の構文:
SET (パラメーター|SESSION AUT HORIZ AT ION) 値
構文ルール:
「パラメーター」は引用符で囲まれていない識別子でなければなりません。空白文字は使用できませ
ん。
「値」は引用符で囲まれていない識別子か引用符で囲まれた文字列リテラルの値になります。
SET ステートメントはプランニングや実行を制御するために最も一般的に使用されます。
SET SHOWPLAN (ON|DEBUG|OFF)
SET NOEXEC (ON|OFF)
21
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
例 3.1 プランデバッグを有効にする
Statement s = connection.createStatement();
s.execute("SET SHOWPLAN DEBUG");
...
Statement s1 = connection.createStatement();
ResultSet rs = s1.executeQuery("select col from table");
ResultSet planRs = s1.exeuteQuery("SHOW PLAN");
planRs.next();
String debugLog = planRs.getString("DEBUG_LOG");
SET ステートメントを使用して認証を制御することも可能です。SET SESSION AUT HORIZ AT ION ス
テートメントは認証情報が現在接続上に設定されている場合に 「再認証」 を実行します。SET
PASSWORD ステートメントを発行して接続の認証情報を変更することもできます。 SET PASSWORD
ステートメントは再認証を実行しません。
例 3.2 セッション承認の変更
Statement s = connection.createStatement();
s.execute("SET PASSWORD 'someval'");
s.execute("SET SESSION AUTHORIZATION 'newuser'");
3.4. SHOW ス テ ー ト メ ン ト
SHOW ステートメントを使用するとさまざまな情報を表示することができます。現在、SHOW ステート
メントは Data Services の言語機能ではなく、JDBC クライアントでのみ処理されます。
SHOW PLAN
SHOW PLAN は、clob 列 PLAN_T EXT や xml 列 PLAN_XML、以前実行されたクエリの値が含ま
れる行を持つ clob 列 DEBUG_LOG が含まれる結果セットを返します。SHOWPLAN が OFF で
あったり、プランがない場合、返される行はありません。SHOWPLAN が DEBUG に設定されて
いない場合、DEBUG_LOG は null 値を返します。
SHOW ANNOT AT IONS
SHOW ANNOT AT IONS は文字列 CAT EGORY、PRIORIT Y、ANNOT AT ION、RESOLUT ION お
よび以前実行されたクエリの各アノテーションに対する行が含まれる結果セットを返します。
SHOWPLAN が OFF であったり、プランがない場合、返される行はありません。
SHOW プロパティー
SHOW プロパティーは SET の逆となるプロパティーで、指定されたプロパティーのプロパ
ティー値を表示します。プロパティーキーと一致する名前を持つ単一の文字列が含まれる結果
セットを返します。
SHOW ALL
SHOW ALL は、NAME 文字列とすべてのプロパティー値に対する行エントリーを持つ VALUE 文
字列が含まれる結果セットを返します。
22
第3章 JD BC API への D ata Services の拡張
SHOW ステートメントは、例3.1「プランデバッグを有効にする」 の通りクエリプランの読み出しに最も
一般的に使用されます。
3.5. ト ラ ン ザ ク シ ョ ン ス テ ー ト メ ン ト
JDBC 接続を直接使用できない場合、トランザクションステートメントを使用してローカルトランザク
ションを制御することができます。
ST ART T RANSACT ION
ST ART T RANSACT ION は connection.setAutoCom m it(false) と同じです。
COMMIT
COMMIT は connection.setAutoCom m it(true) と同じです。
ROLLBACK
ROLLBACK は connection.rollback() と同じで、自動コミットモードへ戻ります。
3.6. 部 分 結 果 モ ー ド
Data Service サーバーは「部分結果」クエリモードをサポートします。このモードはクエリプロセッサー
の挙動を変更するため、一部のデータソースがない場合でもサーバーは結果を返します。
例えば、異なるサプライヤーに対して 2 つのデータソースが存在し、データデザイナーによって 2 つのサ
プライヤーからの情報を結合 (union) する仮想グループが作成されたとします。部分結果クエリモードを
使用せずにアプリケーションがクエリを提出し、1 つのサプライヤーのデータベースがダウンした場合、
仮想グループに対するクエリは例外を返します。しかし、アプリケーションが同じクエリを「部分結果」
クエリモードで実行すると、サーバーは稼働しているデータソースよりデータを返し、ダウンしている
データソースからはデータを返しません。
「部分結果」モードを使用する際、処理中にソースが例外をスローしてもユーザーのクエリが失敗する原
因にはなりません。ソースは障害点の後にこれ以上の行を返さないとみなされます。多くの場合でソース
は 0 行を返します。
不足している情報がうまく処理されるため、 UNION クエリや OUT ER JOIN クエリを使用する時のこの
挙動は大変便利です。他のクエリの多くは部分結果モードで使用された時にソースがないと 0 行を返しま
す。
クエリから除外される各ソースに対して、ソースと障害を説明する警告が生成されます。これらの警告は
Statem ent.getWarnings() メソッドより取得できます。このメソッドは SQLWarning オブジェクト
を返しますが、「部分結果」警告の場合はこのオブジェクトが
org.teiid.jdbc.PartialResultsWarning クラスのインスタンスになります。このクラスを使用
すると、名前ごとに失敗したすべてのソースの一覧を取得したり、各リソースアダプターによってスロー
された特定の例外を取得することができます。
23
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
注記
Data Services は結果全体が形成される前にカーソルの使用をサポートするため、結果の最初の
バッチがクライアントに返されるまでデータソースの失敗が判断されない可能性があります。これ
は union による結合の場合に発生しますが、join では発生しません。確実にすべての警告が蓄積さ
れるようにするため、結果セット全体が読み取られた後にステートメントをチェックする必要があ
ります。
部分結果モードはデフォルトで無効になっていますが、DataSource 上に setPartialResultsMode("true")
を設定するか、JDBC URL に partialResultsMode=true を設定すると接続のすべてのクエリに対して有効
にすることができます。いずれの設定方法でも部分結果モードが後に SET ステートメントと切り替わる
ことがあります。詳細は 「SET ステートメント」 を参照してください。
例 3.3 部分結果モードの設定
Statement statement = ...obtain statement from Connection...
statement.execute("set partialResultsMode true");
例 3.4 部分結果の警告の取得
statement.execute("set partialResultsMode true");
ResultSet results = statement.executeQuery("SELECT Name FROM Accounts");
while (results.next())
{
//process the result set
}
SQLWarning warning = statement.getWarnings();
if(warning instanceof PartialResultsWarning)
{
PartialResultsWarning partialWarning = (PartialResultsWarning)warning;
Collection failedConnectors = partialWarning.getFailedConnectors();
Iterator iter = failedConnectors.iterator();
while(iter.hasNext())
{
String connectorName = (String) iter.next();
SQLException connectorException =
partialWarning.getConnectorException(connectorName);
System.out.println(connectorName + ": " + ConnectorException.getMessage();
}
}
3.7. XML 拡 張
XML 拡張はクエリから XML ドキュメントモデルへの XML 結果に適用されますが、SQL/XML によって作
成された XML や他のソースより読み取られた XML には適用されません。
3.7.1. ドキュメントのフォーマット
24
第3章 JD BC API への D ata Services の拡張
PROP_XML_FORMAT 実行プロパティーを設定して、XML ドキュメントモデルから XML ドキュメントが
フォーマットされる方法を変更することができます。定数の有効な値は同じ ExecutionProperties イ
ンターフェースに定義されています。
XML_T REE_FORMAT
XML_T REE_FORMAT は表示向けにフォーマットされた XML のバージョンを返します。XML は
XML をツリーとしてフォーマットするため適切に改行やタブを使用します。フォーマットに要す
る時間が長く、ドキュメントのサイズも大きいため、フォーマットの速度は遅くなります。
XML_COMPACT _FORMAT
XML_COMPACT _FORMAT はパフォーマンスを最適化するためフォーマットされた XML のバー
ジョンを返します。XML は単一の長い文字列で不必要な空白文字は存在しません。
重要
PROP_XML_FORMAT 実行プロパティーが設定されていない場合、元のモデルにおける XML ドキュ
メントのフォーマットフラグが使用されます。この場合、ドキュメントの設定によりドキュメント
のツリーまたはコンパクトが作成されます。
3.7.2. スキーマ検証
PROP_XML_VALIDAT ION 実行プロパティーを設定すると、クライアントに返す前にサーバーが XML ド
キュメントモデルのドキュメントをスキーマに対して検証するよう示すことができます。スキーマ検証が
有効になっている場合、ドキュメントが関連するスキーマに適合しないとサーバーは SQLWarning を送信
します。スキーマ検証を使用すると XML クエリのパフォーマンスが低下します。
25
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
第 4章 JDBC でのトランザクション
Data Services の JDBC API はクライアントの観点からグローバル、ローカル、要求レベルの 3 種類のト
ランザクションをサポートとします。これらのトランザクションはすべて Data Services サーバーによっ
て XA トランザクションとして実装されます。XA トランザクションの詳細は
http://www.oracle.com/technetwork/java/javaee/tech/jta-138684.html の JT A 仕様を参照してください。
4.1. ロ ー カ ル ト ラ ン ザ ク シ ョ ン
接続クラスは autoCom m it フラグを使用してローカルトランザクションを明示的に制御します。デフォ
ルトでは autoCommit は要求レベルまたは黙示的トランザクションの制御を示す true に設定されていま
す。例4.1「autoCommit を使用したローカルトランザクションの制御」 を参照してください。
例 4 .1 autoCommit を使用したローカルトランザクションの制御
// Set auto commit to false and start a transaction
connection.setAutoCommit(false);
try
{
// Execute multiple updates
Statement statement = connection.createStatement();
statement.executeUpdate("INSERT INTO Accounts (ID, Name) VALUES (10,
‘Mike’)");
statement.executeUpdate("INSERT INTO Accounts (ID, Name) VALUES (15,
‘John’)");
statement.close();
// Commit the transaction
connection.commit();
}
catch(SQLException e)
{
// If an error occurs, rollback the transaction
connection.rollback();
}
この例では次の項目が実行されます。
1. autoCom m it フラグを false に設定します。トランザクションの接続へのバインドを開始します。
2. トランザクションのコンテキスト内で複数の更新を実行します。
3. ステートメントが完了すると、com m it() を呼び出してトランザクションがコミットされます。
4. エラーが発生すると rollback() メソッドを使用してトランザクションがロールバックされま
す。
次の操作はいずれもローカルトランザクションを終了します。
1. Connection.setAutoCom m it(true) - 以前 false に設定された場合
2. Connection.com m it()
3. Connection.rollback()
4. タイムアウトするとトランザクションは自動的にロールバックされます。
26
第4章 JD BC でのトランザクション
場合によってはすべてのアクセスが読み取り専用でトランザクションが必要でない時でも Data Services
より上のツールやフレームワークが setAutoCom m it(false) や com m it()、rollback() を呼び出
すことがあります。ローカルトランザクションの範囲では Data Services が起動し、XA トランザクショ
ンをコミットしようとするため、設定が複雑になったりパフォーマンスが劣化する原因となることがあり
ます。
このような場合、デフォルトの JDBC の動作を上書きし、実行されたコマンドに関係なくこれらのメソッ
ドは何も実行しないよう示すことができます。ローカルトランザクションの使用を無効にするには、この
プロパティーを JDBC 接続 URL に追加します。
disableLocalTxn=true
警告
ローカルトランザクションを無効にすると危険な場合があります。読み取り時に結果が不整合と
なったり、書き込み時にデータストアのデータが不整合となることがあります。安全性を保つた
め、呼び出しアプリケーションがローカルトランザクションを必要としないことが確定している場
合のみこのモジュールを使用するようにしてください。
4.2. 要 求 レ ベ ル ト ラ ン ザ ク シ ョ ン
要求レベルトランザクションは、要求がグローバルトランザクションまたはローカルトランザクションの
範囲にない場合 (autoCom m it が true の場合) に使用されます。要求レベルトランザクションではアプ
リケーションが明示的にコミットやロールバックを呼び出す必要はありません。各コマンドは、サーバー
によって自動的にコミットまたはロールバックされる独自のトランザクションとなることが想定されま
す。
Data Services サーバーは仮想テーブルより更新を実行できます。これらの更新によって、アプリケー
ションが単一の仮想テーブルに対して更新コマンドを発行した場合でも複数の物理システムに対して更新
が行われることがあります。ほとんどの場合でユーザーはクエリ済みテーブルが複数のソースを更新しト
ランザクションが必要となることを認識しません。
そのため、Data Services サーバーは必要な場合にアプリケーションがトランザクションでコマンドを自
動的にラップできるようにします。このラッピングはクエリのパフォーマンスに影響するため、複数の
ラッピングモードよりご使用の環境に合ったモードを選択することができます。アプリケーションが必要
とするのは高い整合性か高いパフォーマンスのどちらかであるか選択する必要があります。例えば、デー
タソースがトランザクションに対応していない場合、トランザクションのラッピングを (完全に) 無効にし
てパフォーマンスを最大限に向上するとよいでしょう。
トランザクションラッピングを以下のモードの 1 つに設定することが可能です。
1. ON
このモードは必要性を確認せずに常にトランザクションのコマンドをラップします。これが最も安
全なモードです。
2. OFF
このモードはトランザクションのコマンドを自動的にラップせず、コマンドをラップする必要性も
確認しません。このモードではエラーを出さずにトランザクション外部のソースを複数更新できる
ため、危険な場合があります。このモードでは更新やトランザクションを使用しないアプリケー
ションのパフォーマンスが最良となります。
3. DET ECT
27
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
このモードはトランザクションで複数ソースの更新が実行されることをユーザーが認識しないと想
定します。Data Services サーバーは各コマンドをチェックし、複数ソースの更新であるかを確認
しトランザクション内でラップします。単一ソースの場合はソースレベルのコマンドトランザク
ションを使用します。
実行プロパティーを使用して接続を確立する時やクエリごとにトランザクションモードをプロパティーと
して設定することができます。詳細は 「実行プロパティー」 を参照してください。
4.2.1. 複数挿入バッチ
クエリ表現 (または廃止された SELECT INT O) で INSERT を発行すると、個別のソースの INSERT に
よって処理される複数の挿入バッチが Data Servces サーバーによって処理されることがあります。目的
のソースが XA をサポートしていることを確認してください。サポートしていない場合、障害が発生する
と補正処理が行われます。
4.3. グ ロ ー バ ル ト ラ ン ザ ク シ ョ ン の 使 用
グローバルまたはクライアント XA トランザクションは Data Services JDBC API が単一のクライアントリ
ソースの範囲を越えるトランザクションに参加できるようにします。この場合、接続の確立に Data
Services の DataSource クラスを使用します。
JBoss や WebSphere、Weblogic などのアプリケーションサーバーにおける UserT ransaction のコンテ
キストで DataSource が使用されると、結果として生じる接続には現在の XA トランザクションが関連付
けされます。XA トランザクションとの対話に必要な追加のクライアント JDBC コードはありません。
28
第4章 JD BC でのトランザクション
例 4 .2 手作業による XA トランザクションの使用
XAConnection xaConn = null;
XAResource xaRes = null;
Connection conn = null;
Statement stmt = null;
try
{
xaConn = <XADataSource instance>.getXAConnection();
xaRes = xaConn.getXAResource();
Xid xid = <new Xid instance>;
conn = xaConn.getConnection();
stmt = conn.createStatement();
xaRes.start(xid, XAResource.TMNOFLAGS);
stmt.executeUpdate("insert into …");
// other statements on this connection or other resources enlisted in this
transaction
// ...
xaRes.end(xid, XAResource.TMSUCCESS);
if (xaRes.prepare(xid) == XAResource.XA_OK)
{
xaRes.commit(xid, false);
}
}
catch (XAException e)
{
xaRes.rollback(xid);
}
finally
{
// clean up code
// ...
}
グローバルトランザクションを使用すると複数の Data Services XAConnections が同じトランザクション
に参加することができます。Data Services JDBC XAResource の isSam eRM() メソッドはクラスターの
同じサーバーインスタンスへ接続が確立されている場合に true のみを返すことに注意してください。
Data Services の接続が異なるサーバーインスタンスへ確立されていると、同じクラスターメンバーの場
合とはトランザクションの挙動が異なることがあります。例えば、クライアントトランザクションマネー
ジャーが各接続に同じ XID を使用する場合、異なるクラスターメンバーよりアクセスされた同じ物理ソー
スより重複した XID 例外が発生することがあります。クライアントトランザクションマネージャーが各接
続に異なるブランチ識別子を使用する場合、ブランチ識別子に従って変更をロックしたり分離するソース
に問題が発生することがあります。
4.4. 制 限
4.4.1. アプリケーションの制限
グローバルやローカル、要求レベルのトランザクションの使用はすべて相互排他的です。要求レベルトラ
ンザクションはグローバルまたはローカルトランザクションにない時のみ適用されます。グローバルトラ
ンザクションとローカルトランザクションを同時に組み合わせると例外が発生します。
29
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
4.4.2. エンタープライズ情報システムサポート
エンタープライズ情報システム (EIS) を表す基盤のリソースアダプターや EIS 自体は、XA トランザクショ
ンが Data Services を使用して分散 XA トランザクションに参加できるようサポートしなければなりませ
ん。ソースシステムが XA をサポートしない場合、分散トランザクションには参加できません。しかし、
ソースは XA サポートがなくてもデータの統合には参加することができます。
XA トランザクションへの参加はリソースアダプターの XA 機能に従って自動的に判断されます。分散トラ
ンザクションへの参加が必要な場合、開発者が責任を持って XA リソースを設定するようにしてくださ
い。
30
第5章 SSL クライアント接続
第 5章 SSL クライアント接続
本章ではトランスポートレベルでのデータアクセスの保護を目的とした Data Services で使用できる異な
るセキュリティー設定について説明します。データレベルセキュリティーであるデータロールについての
詳細は、リファレンスガイドのデータロールの章を参照してください。
5.1. デ フ ォ ル ト の セ キ ュ リ テ ィ ー
デフォルトでは、接続ごとにネゴシエートされる http://en.wikipedia.org/wiki/DiffieHellman_key_exchange キーを使用してクライアントサーバー間に存在するすべての JDBC/管理に影響さ
れる (非データ) メッセージが暗号化されます。この暗号化は JdbcSslConfiguration の
clientEncryptionEnabled プロパティーと jboss-beans ファイルの Adm inSslConfiguration
セクションによって制御されます。
ソケット接続を使用している場合、更にチャネルを安全にする必要があります。特に ODBC は現在プレー
ンテキストの認証のみをサポートしているため更なるセキュリティーが必要です。
5.2. SSL モ デ ル
Data Services は クライアント JDBC アプリケーションと Data Services サーバーの間で SSL ベースの
チャネルをサポートします。Data Services は次の SSL モードをサポートします。
1. 匿名 (Anonymous) - 証明書は必要ありませんが、すべての通信が
T LS_DH_anon_WIT H_AES_128_CBC_SHA SSL スイートを使用して暗号化されます。
2. 一方向 (1-way) – サーバーからクライアントへのトラフィックのみが認証されます。サーバーと
キーを認証するクライアントのトラストストアに対して秘密鍵のキーストアを作成する必要があり
ます。SSL スイートがネゴシエートされます。
3. 双方向 (2-way) – クライアントとサーバーの相互認証です。サーバーアプリケーションとクライア
ントアプリケーションはそれぞれ秘密鍵のキーストアと相手側を認証するトラストストアを保有し
ています。
SSL モードによっては組織での秘密鍵の作成や取得のガイドラインに従うようにしてください。組織にお
ける必要条件がない場合、本ガイドに従って対応するキーストアとトラストストアで自己署名証明書を作
成してください。詳細は 付録B Keytool を用いた自己署名証明書の生成 を参照してください。
異なる SSL モードに必要となるキーストアとトラストストアの組み合わせは次の通りです。ファイル名は
例として使用されているため、変更することが可能です。
一方向
server.keystore - サーバーの秘密鍵を保有
server.truststore - サーバーの公開鍵を保有
双方向
server.keystore - サーバーの秘密鍵を保有
server.truststore - サーバーの公開鍵を保有
client.keystore - クライアントの秘密鍵
client.truststore - クライアントの公開鍵を保有
31
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
5.3. ク ラ イ ア ン ト の SSL 設 定
各 SSL モードに必要なプロパティーを定義するセクションは次の通りです。
重要
Data Services の設定ではデフォルトで SSL が有効になっています。SSL が有効な状態で Data
Services サーバーに接続する時、jdbc:teiid:MY-VDB@ m m s://HOST:PORT のように JDBC 接
続 URL の代わりに m m s プロトコルを使用する必要があります。
一方向 SSLや双方向 SSL を有効するためにクライアントが設定できるプロパティーは 2 セットありま
す。
5.3.1. オプション 1: Java SSL プロパティー
JVM 以下に SSL を設定する標準的な Java が定義されたシステムプロパティーがあります。Data
Serivces による SSL の使用は独自なものではありません。次のシステムプロパティーをクライアントの
VM 処理に提供します。
例 5.1 一方向 SSL
-Djavax.net.ssl.trustStore=<dir>/server.truststore (required)
-Djavax.net.ssl.trustStorePassword=<password> (optional)
-Djavax.net.ssl.keyStoreType (optional)
例 5.2 2 方向 SSL
-Djavax.net.ssl.keyStore=<dir>/client.keystore (required)
-Djavax.net.ssl.keyStrorePassword=<password> (optional)
-Djavax.net.ssl.trustStore=<dir>/server.truststore (required)
-Djavax.net.ssl.trustStorePassword=<password> (optioanl)
-Djavax.net.ssl.keyStroreType=<keystore type> (optional)
5.3.2. オプション 2: Deta Services 固有のプロパティー
このオプションは、匿名モードの場合や上記の javax ベースのプロパティーがホストプロセスによって
既に使用されている場合に使用します。例えば、クライアントアプリケーションが HT T PS に対して設定
された T omcat のプロセスで、上記の Java ベースのプロパティーが既に使用されている場合、Data
Services 固有の証明書キーを HT T PS 証明書キーストアへインポートすることはできません。
この場合、異なるセットの Data Services 固有の SSL プロパティーをシステムプロパティーとして設定し
たり、teiid-client-settings.properties ファイルの内部を設定することができます。teiid-clientsettings.properties ファイルはルートの teiid-client.jar ファイルの中にあります。このファイルを
展開するかコピーを作成し、選択した SSL モードに必要なプロパティー値を変更した後、クライアントア
プリケーションのクラスパス上で teiid-client.jar ファイルの前にこのファイルを置きます。
teiid-client-settings.properties 内の SSL プロパティーおよび定義は次の通りです。
32
第5章 SSL クライアント接続
########################################
# SSL Settings
########################################
#
# The key store type.
#
Defaults to JKS
org.teiid.ssl.keyStoreType=JKS
#
# The key store algorithm, defaults to
# the system property "ssl.TrustManagerFactory.algorithm"
#
#org.teiid.ssl.algorithm=
#
#
#
#
#
#
#
#
The classpath or filesystem location of the
key store.
This property is required only if performing 2-way
authentication that requires a specific private
key.
#org.teiid.ssl.keyStore=
#
# The key store password (not required)
#
#org.teiid.ssl.keyStorePassword=
#
#
#
#
#
#
#
#
The classpath or filesystem location of the
trust store.
This property is required if performing 1-way
authentication that requires trust not provided
by the system defaults.
#org.teiid.ssl.trustStore=
#
# The trust store password (not required)
#
#org.teiid.ssl.trustStorePassword=
#
# The cipher protocol, defaults to SSLv3
#
org.teiid.ssl.protocol=SSLv3
#
# Whether to allow anonymous SSL
# (the TLS_DH_anon_WITH_AES_128_CBC_SHA cipher suite)
33
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
# defaults to true
#
org.teiid.ssl.allowAnon=true
例 5.3 一方向 SSL
org.teiid.ssl.trustStore=<dir>/server.truststore (required)
例 5.4 2 方向 SSL
org.teiid.ssl.keyStore=<dir>/client.keystore (required)
org.teiid.ssl.trustStore=<dir>/server.truststore (required)
例 5.5 匿名
org.teiid.ssl.trustStore=NONE
34
第6章 D ata Services を Hibernate と使用する
第 6章 Data Services を Hibernate と使用する
6.1. 制 限
Hibernate の多くのユースケースでは、データソースが CREAT E T ABLE や DROP T ABLE などの DDL
(データ定義言語) ステートメントと SELECT 、UPDAT E、INSERT 、DELET E などの DML (データ操
作言語) ステートメントを処理できる能力 (適切なユーザーパーミッションにより) を持っていること
を前提としています。 T eiid は広範囲の DML に対応できますが、特定ソースに対する DDL を直接サ
ポートしていません。
シーケンスとアイデンティティーの生成はサポートされていません。hilo ジェネレーターなど、テーブ
ル値を基にした識別子の生成には T eiid を介して識別子テーブルを公開する必要があります。GUID 識
別子生成のストラテジーは直接サポートされます。
6.2. 設 定
大部分では、Hibernate より Data Services の VDB (仮想データベース) と対話することは他のタイプの
データソースと動作することと同じになります。最初に Data Services の DBC API クライアント JAR
ファイルと Data Services の Hibernate ダイアレクト JAR を Hibernate のクラスパスに置きます。
下記のファイルは JBOSS_HOME/server/PROFILE/lib ディレクトリにあります。
teiid-client.jar
teiid-hibernate-dialect-7.1.1.jar
これらの JAR ファイルには org.teiid.dialect.T eiidDialect や
org.teiid.jdbc.T eiidDriver、 org.teiid.jdbc.T eiidDataSource クラスがあります。
次に 手順6.1「Hibernate の設定」 に従って hibernate.cfg.xm l ファイルに Hibernate を設定しま
す。VDB-NAME、HOST 、PORT 、USERNAME、 PASSWORD を適切な値に置き換えます。
手順 6.1 Hibernate の設定
1. Data Services のドライバークラスの指定
connection.driver_class プロパティーに Data Services ドライバークラスを指定します。
<property name="connection.driver_class">
org.teiid.jdbc.TeiidDriver
</property>
2. 接続 URL の設定
connection.url プロパティーに VDB の URL を指定します。
<property name="connection.url">
jdbc:teiid:VDB-NAME@mm://HOST:POST;user=USERNAME;password=PASSWORD
</property>
注記
Hibernate が アプリケーションサーバーと同じ VM にある場合、必ず 「ローカル JDBC 接
続」 を使用してください。
35
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
3. dialect プロパティーに Data Services のダイアレクトクラスを指定する
<property name="dialect">
org.teiid.dialect.TeiidDialect
</property>
hibernate.cfg.xm l の代わりに hibernate.properties ファイルに接続プロパティーを追
加することもできます。
hibernate.connection.driver_class=org.teiid.jdbc.TeiidDriver
hibernate.connection.url=jdbc:teiid:VDB-NAME@mm://HOST:PORT
hibernate.connection.username=USERNAME
hibernate.connection.password=PASSWORD
hibernate.dialect=org.teiid.dialect.TeiidDialect
VDB に同じテーブル名を持つ複数のソースモデルやビューモデルが含まれている可能性が高いため、
Hibernate マッピングファイルに完全修飾テーブル名を指定する必要があります。
<class name="CLASSNAME" table="SOURCE/VIEW_MODEL_NAME.[SCHEMA_NAME.]TABLENAME">
...
</class>
例 6.1 マッピング例
<class name="org.teiid.example.Publisher" table="BOOKS.BOOKS.PUBLISHERS">
...
</class>
36
第7章 OD BC サポート
第 7章 ODBC サポート
JBoss Enterprise Data Services は PostgreSQL データベースサーバーをエミュレートして ODBC (Open
DataBase Connectivity) のアクセスをデプロイされた VDB に提供します。 デフォルトでは JBoss
Enterprise Data Services 上の ODBC は 354 32 番ポートで有効になっています。ODBC 準拠のクライア
ントアプリケーションはサポート対象の PostgreSQL ODBC ドライバーを使用して VDB に接続すること
ができます。サポート対象の PostgreSQL ODBC ドライバーは http://access.redhat.com よりダウンロー
ドできます。
注記
ODBC は標準化されたデータベースアクセス方法で、1992 年に SQL Access グループによって開
発されました。Java の JDBC と同様に、使用されているデータベース管理システム (DBMS) に関
係なく一貫性のあるクライアントアクセスを可能にします。
警告
現在、T eiid は ODBC に対してプレーンテキストのパスワード認証のみをサポートしています。ク
ライアントサーバーが SSL を使用するよう設定されていない場合、パスワードはネットワーク上
でプレーンテキストにて送信されます。SSL を使用せずに送信中のパスワードを保護する必要があ
る場合は、クライアントからの安全なパスワード値を許可する (暗号化またはハッシュ化など) セ
キュリティードメインをインストールするようにしてください。
7.1. ODBC ド ラ イ バ ー ク ラ イ ア ン ト の イ ン ス ト ー ル
異なるオペレーティングシステムでサポートされる PostgreSQL ODBC ドライバーのインストールパッ
ケージは http://access.redhat.com よりダウンロードできます。
Red Hat Enterprise Linux や その他サポート対象オペレーティングシステム向けのドライバーパッケージ
をインストールおよび設定する手順は以下の項を参照してください。
重要
ODBC の設定には管理パーミッションを持つユーザーアカウントが必要となります。Red Hat
Enterprise Linux やその他の UNIX オペレーティングシステムでは sudo コマンドの使用や root
ユーザーアカウントへのアクセスを許可する必要があります。Microsoft Windows では管理者アカ
ウント使用する必要があります。
7.1.1. Red Hat Enterprise Linux やその他の UNIX オペレーティングシステムに
ODBC ドライバーをインストールする
手順 7.1 Red Hat Enterprise Linux やその他の UNIX オペレーティングシステムに ODBC ドライ
バーをインストールする
1. ダウンロード
http://access.redhat.com よりご使用のオペレーティングシステム向けの正しい ODBC ドライバー
インストールパッケージをダウンロードします。
2. パッケージの解凍
37
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
/opt ディレクトリにインストールパッケージを展開します。
3. 環境の設定
/opt/redhat/eds-5.x/etc/setenv.sh スクリプトを実行します。
[localhost etc]$ ./setenv.sh
このスクリプトは必要なディレクトリを LD_LIBRARY_PAT H および PAT H 環境変数に追加しま
す。
4. DSN の設定
/opt/redhat/eds-5.x/etc/odbc.ini ファイルを編集し、正しいユーザー名、パスワード、
データベースで更新します。データベース名は VDB 名です。
[<DSN name>]
Driver = /usr/lib/psqlodbc.so
Description = PostgreSQL Data Source
Servername = <Teiid Host name or ip>
Port = 35432
Protocol = 7.4-1
UserName = <user-name>
Password = <password>
Database = <vdb-name>
ReadOnly = no
ServerType = Postgres
ConnSettings =
UseServerSidePrepare=1
ByteaAsLongVarBinary=1
Optimizer=0
Ksqo=0
Debug=0
Fetch = 10000
# enable below when dealing large resultsets
#UseDeclareFetch=1
5. 完了
これで ODBC ドライバーが適切にインストールされ、eds という名前の DSN が使用できるように
なります。
7.1.2. Microsoft Windows に ODBC ドライバーをインストールする
手順 7.2 Microsoft Windows に ODBC ドライバーをインストールする
1. ダウンロード
http://access.redhat.com よりご使用のオペレーティングシステム向けの正しい ODBC ドライバー
インストールパッケージをダウンロードします。
2. インストーラーの解凍および実行
インストールパッケージを解凍し、setup.exe 実行可能ファイルをダブルクリックしてインス
トーラーを開始します。
3. インストール場所の提供
インストーラーより入力を求められたら ODBC ドライバーをインストールするディレクトリを入力
します。
4. 完了
インストーラーが必要なファイルを指定場所へコピーします。これで ODBC ドライバーが使用でき
るようになります。
38
第7章 OD BC サポート
5. DSN の設定
a. ODBC データソース管理者アプレットを開く
Start menu より以下を実行します。
Settings の選択後、Control Panel を選択します。
Administrative T ools をダブルクリックします。
Data Sources (ODBC) をダブルクリックします。
これで ODBC データソース管理者アプレットが表示されます。
b. DSN の追加
追加したい DSN のタイプに関連するタブをクリックします。Create New Data Source
ダイアログボックスが開きます。データソーステーブルのドライバーとして PostgreSQL
Unicode を選択し、Finish をクリックすると PostgreSQL Unicode ODBC Driver
Setup ダイアログボックスが開きます。
図 7.1 PostgreSQL の Unicode ODBC ドライバーの設定
c. 詳細の入力
次の内容を PostgreSQL ODBC Driver Setup ダイアログボックスに入力します。
Data Source フィールドにデータソースに割り当てたい名前を入力します
Database フィールドにこのデータソースを使用してアクセスする VDB の名前を入力し
ます。
Server フィールドに Data Services サーバーのホスト名か IP アドレスを入力します。
ファイアウォールや NAT アドレスを使用して接続する場合はファイアウォールまたは
NAT アドレスを使用します。
Port フィールドに Data Services システムが ODBC 要求をリッスンするポートの番号を
入力します。Data Services によって使用されるデフォルトのポート番号は 354 32 で
す。
User Nam e および Password フィールドに Data Services サーバーへの接続に使用す
るユーザー名とパスワードを入力します。
SSL Mode は disable のままにしておいてください。 現在 SSL 接続はサポートされて
いません。
Description フィールドにデータソースの説明を入力します。
d. オプションページ 1
Datasource ボタンをクリックして Advanced Options ダイアログボックスを表示しま
す。
39
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
図7.2「DSN オプションページ 1」 の通りオプションを設定します。
図 7.2 DSN オプションページ 1
e. オプションページ 2
Page 2 ボタンをクリックしてオプションの 2 ページ目を表示します。
図7.3「DSN オプションページ 2」 の通りオプションを設定し、OK をクリックします。
40
第7章 OD BC サポート
図 7.3 DSN オプションページ 2
f. 保存およびテスト
Save をクリックして変更を保存します。T est ボタンをクリックして接続が有効であるか確
認することもできます。
41
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
サポート対象外の JDBC メソッド
本付録は JDK 1.6 JDBC を基にした Data Services ではサポートされない JDBC メソッドの一覧を提供し
ます。下記に指定がない限り Data Services は他のメソッドをすべてサポートします。
一覧にあるメソッドでコメントのないものは、サポート対象外であることを示し、SQLException タイ
プの例外をスローします。
記載されている通り、例外をスローしないメソッドもありますが、想定外の動作をする可能性がありま
す。引数の指定がない場合、関連 (上書き) するメソッドもすべてサポート対象外となります。引数が指定
されている場合、指定のあるメソッドの形式のみがサポート対象外となります。
A.1. ResultSet の 制 限
T YPE_SCROLL_SENSIT IVE はサポートされません。
UPDAT ABLE ResultSet はサポートされません。
プロシージャの実行より複数の ResultSet を返すことはサポートされません。
A.2. java.sql の サ ポ ー ト 対 象 外 の ク ラ ス お よ び メ ソ ッ ド
42
サポート対象外の JD BC メソッド
表 A.1 接続プロパティー
クラス名
メソッド
Array
Not Supported
Blob
getBinaryStream(long, long) SQLFeatureNotSupportedException をスロー
setBinaryStream(long) - - SQLFeatureNotSupportedException
をスロー
setBytes - - SQLFeatureNotSupportedException をスロー
truncate(long) - SQLFeatureNotSupportedException をスロー
CallableStatem ent
43
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
CallableStatem ent
getArray - SQLFeatureNotSupportedException をスロー
getBigDecimal(String parameterName)SQLFeatureNotSupportedException をスロー
getBlob(String parameterName)SQLFeatureNotSupportedException をスロー
getBoolean(String parameterName)SQLFeatureNotSupportedException をスロー
getByte(String parameterName)SQLFeatureNotSupportedException をスロー
getBytes(String parameterName)SQLFeatureNotSupportedException をスロー
getCharacterStream(String parameterName)SQLFeatureNotSupportedException をスロー
getClob(String parameterName)SQLFeatureNotSupportedException をスロー
getDate(String parameterName, *)SQLFeatureNotSupportedException をスロー
getDouble(String parameterName)SQLFeatureNotSupportedException をスロー
getFloat(String parameterName)SQLFeatureNotSupportedException をスロー
getInt(String parameterName)SQLFeatureNotSupportedException をスロー
getLong(String parameterName)SQLFeatureNotSupportedException をスロー
getNCharacterStream - SQLFeatureNotSupportedException をス
ロー
getNClob - SQLFeatureNotSupportedException をスロー
getNString - SQLFeatureNotSupportedException をスロー
getObject(int parameterIndex, Map<String, Class<?>> map) SQLFeatureNotSupportedException をスロー
getObject(String parameterName) SQLFeatureNotSupportedException をスロー
getRef - SQLFeatureNotSupportedException をスロー
getRowId - SQLFeatureNotSupportedException をスロー
getShort(String parameterName) SQLFeatureNotSupportedException をスロー
getSQLXML(String parameterName) SQLFeatureNotSupportedException をスロー
getString(String parameterName) SQLFeatureNotSupportedException をスロー
getTime(String parameterName, *) SQLFeatureNotSupportedException をスロー
getTimestamp(String parameterName, *) SQLFeatureNotSupportedException をスロー
getURL(String parameterName) SQLFeatureNotSupportedException をスロー
registerOutParameter - 無視
registerOutParameter(String parameterName, *) SQLFeatureNotSupportedException をスロー
setAsciiStream - SQLFeatureNotSupportedException をスロー
setBigDecimal(String parameterName, BigDecimal x)SQLFeatureNotSupportedException をスロー
setBinaryStream(String parameterName, *) SQLFeatureNotSupportedException をスロー
setBlob(String parameterName, *)SQLFeatureNotSupportedException をスロー
setBoolean(String parameterName, boolean x) SQLFeatureNotSupportedException をスロー
setByte(String parameterName, byte x) -
44
サポート対象外の JD BC メソッド
SQLFeatureNotSupportedException をスロー
setBytes(String parameterName, byte[] x) SQLFeatureNotSupportedException をスロー
setCharacterStream - SQLFeatureNotSupportedException をス
ロー
setClob(String parameterName, *) SQLFeatureNotSupportedException をスロー
setDate(String parameterName, *) SQLFeatureNotSupportedException をスロー
setDouble(String parameterName, double x) SQLFeatureNotSupportedException をスロー
setFloat(String parameterName, float x) SQLFeatureNotSupportedException をスロー
setLong(String parameterName, long x) SQLFeatureNotSupportedException をスロー
setNCharacterStream - SQLFeatureNotSupportedException をス
ロー
setNClob - SQLFeatureNotSupportedException をスロー
setNString - SQLFeatureNotSupportedException をスロー
setNull - SQLFeatureNotSupportedException をスロー
setObject(String parameterName, *) SQLFeatureNotSupportedException をスロー
setRowId(String parameterName, RowId x) SQLFeatureNotSupportedException をスロー
setSQLXML(String parameterName, SQLXML xmlObject) SQLFeatureNotSupportedException をスロー
setShort(String parameterName, short x) SQLFeatureNotSupportedException をスロー
setString(String parameterName, String x) SQLFeatureNotSupportedException をスロー
setTime(String parameterName, *) SQLFeatureNotSupportedException をスロー
setTimestamp(String parameterName, *) SQLFeatureNotSupportedException をスロー
setURL(String parameterName, URL val) SQLFeatureNotSupportedException をスロー
Clob
getCharacterStream(long arg0, long arg1) SQLFeatureNotSupportedException をスロー
setAsciiStream(long arg0) - SQLFeatureNotSupportedException
をスロー
setCharacterStream(long arg0) SQLFeatureNotSupportedException をスロー
setString - SQLFeatureNotSupportedException をスロー
truncate - SQLFeatureNotSupportedException をスロー
Connection
45
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
Connection
createArrayOf - SQLFeatureNotSupportedException をスロー
createBlob - SQLFeatureNotSupportedException をスロー
createClob - SQLFeatureNotSupportedException をスロー
createNClob - SQLFeatureNotSupportedException をスロー
createSQLXML - SQLFeatureNotSupportedException をスロー
createStatement(int resultSetType,int resultSetConcurrency,
int resultSetHoldability) - SQLFeatureNotSupportedException
createStruct(String typeName, Object[] attributes) SQLFeatureNotSupportedException をスロー
getClientInfo - SQLFeatureNotSupportedException をスロー
prepareCall(String sql, int resultSetType,int
resultSetConcurrency, int resultSetHoldability) SQLFeatureNotSupportedException をスロー
prepareStatement(String sql, int autoGeneratedKeys) SQLFeatureNotSupportedException をスロー
prepareStatement(String sql, int[] columnIndexes) SQLFeatureNotSupportedException をスロー
prepareStatement(String sql, String[] columnNames) SQLFeatureNotSupportedException をスロー
releaseSavepoint - SQLFeatureNotSupportedException をスロー
rollback(Savepoint savepoint) SQLFeatureNotSupportedException をスロー
setHoldability - SQLFeatureNotSupportedException をスロー
setSavepoint - SQLFeatureNotSupportedException をスロー
setTypeMap - SQLFeatureNotSupportedException をスロー
DatabaseMetaData
getAttributes - SQLFeatureNotSupportedException をスロー
getClientInfoProperties - SQLFeatureNotSupportedException
をスロー
getFunctionColumns - SQLFeatureNotSupportedException をス
ロー
getFunctions - SQLFeatureNotSupportedException をスロー
getRowIdLifetime - SQLFeatureNotSupportedException をスロー
NClob
Not Supported
PreparedStatem ent
execute(String sql) - SQLException をスロー
executeQuery(String sql) - SQLException をスロー
executeUpdate(String sql) - SQLException をスロー
setArray - SQLFeatureNotSupportedException をスロー
setNCharacterStream - SQLFeatureNotSupportedException をス
ロー
setNClob - SQLFeatureNotSupportedException をスロー
setRef - SQLFeatureNotSupportedException をスロー
setRowId - SQLFeatureNotSupportedException をスロー
setUnicodeStream - SQLFeatureNotSupportedException をスロー
Ref
ResultSet
46
Not Im plem ented
サポート対象外の JD BC メソッド
ResultSet
deleteRow - SQLFeatureNotSupportedException をスロー
getArray - SQLFeatureNotSupportedException をスロー
getAsciiStream - SQLFeatureNotSupportedException をスロー
getHoldability - SQLFeatureNotSupportedException をスロー
getNCharacterStream - SQLFeatureNotSupportedException をス
ロー
getNClob - SQLFeatureNotSupportedException をスロー
getNString - SQLFeatureNotSupportedException をスロー
getObject(*, Map<String, Class<?>> map) SQLFeatureNotSupportedException をスロー
getRef - SQLFeatureNotSupportedException をスロー
getRowId - SQLFeatureNotSupportedException をスロー
getUnicodeStream - SQLFeatureNotSupportedException をスロー
getURL - SQLFeatureNotSupportedException をスロー
insertRow - SQLFeatureNotSupportedException をスロー
moveToInsertRow - SQLFeatureNotSupportedException をスロー
refreshRow - SQLFeatureNotSupportedException をスロー
rowDeleted - SQLFeatureNotSupportedException をスロー
rowInserted - SQLFeatureNotSupportedException をスロー
rowUpdated - SQLFeatureNotSupportedException をスロー
setFetchDirection - SQLFeatureNotSupportedException をスロー
update* - SQLFeatureNotSupportedException をスロー
RowId
Not Supported
Savepoint
not Supported
SQLData
Not Supported
SQLInput
not Supported
SQLOutput
Not Supported
Statem ent
execute(String, int)
execute(String, int[])
execute(String, String[])
executeUpdate(String, int)
executeUpdate(String, int[])
executeUpdate(String, String[])
getGeneratedKeys()
getResultSetHoldability()
setCursorName(String)
Struct
Not Supported
A.3. javax.sql の サ ポ ー ト 対 象 外 の ク ラ ス お よ び メ ソ ッ ド
表 A.2 接続プロパティー
クラス名
メソッド
RowSet*
Not Supported
Statem entEventListener
Not Supported
47
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
Keytool を用いた自己署名証明書の生成
自己署名証明書を生成するには、Java SDK のすべてのバージョンに含まれる「keytool」と呼ばれるプロ
グラムが必要となります。以下の手順は、セキュリティーキーを持つ一方向 SSL 設定にキーストアファイ
ルとトラストストアファイルの両方を作成する手順となります。
B.1. 秘 密 鍵 と 公 開 鍵 の ペ ア の 作 成
keytool -genkey -alias teiid -keyalg RSA -validity 365 –keystore
server.keystore –storetype JKS
Enter keystore password: <enter password>
What is your first and last name?
[Unknown]: <user’s name>
What is the name of your organizational unit?
[Unknown]: <department name>
What is the name of your organization?
[Unknown]: <company name>
What is the name of your City or Locality?
[Unknown]: <city name>
What is the name of your State or Province?
[Unknown]: <state name>
What is the two-letter country code for this unit?
[Unknown]: <country name>
Is CN=<user’s name>, OU=<department name>, O="<company name>",
L=<city name>, ST=<state name>, C=<country name> correct?
[no]: yes
Enter key password for <server>
(Return if same as keystore password)
新規作成した秘密鍵を基に server.keystore をキーストアとして使用することができます。
B.2. 公 開 鍵 の 抽 出
上記で作成した server.keystore よりトラストストアを作成するための公開鍵を抽出することができま
す。
keytool -export -alias teiid –keystore server.keystore -rfc -file public.cert
Enter keystore password: <enter passsword>
上記は server.keystore の秘密鍵を基に公開鍵が含まれる public.cert ファイルを作成します。
B.3. ト ラ ス ト ス ト ア の 作 成
48
Keytool を用いた自己署名証明書の生成
keytool -import -alias teiid -file public.cert –storetype JKS -keystore
server.truststore
Enter keystore password: <enter password>
Owner: CN=<user's name>, OU=<dept name>, O=<company name>, L=<city>, ST=<state>,
C=<country>
Issuer: CN=<user's name>, OU=<dept name>, O=<company name>, L=<city>, ST=<state>,
C=<country>
Serial number: 416d8636
Valid from: Fri Jul 31 14:47:02 CDT 2009 until: Sat Jul 31 14:47:02 CDT 2010
Certificate fingerprints:
MD5: 22:4C:A4:9D:2E:C8:CA:E8:81:5D:81:35:A1:84:78:2F
SHA1: 05:FE:43:CC:EA:39:DC:1C:1E:40:26:45:B7:12:1C:B9:22:1E:64:63
Trust this certificate? [no]: yes
これで server.truststore が作成されました。自己署名証明書を作成する方法はたくさんあるため上
記の手順はその1つとなります。openssl を使用して自己署名証明書を作成するには
http://www.akadia.com/services/ssh_test_certificate.html のチュートリアルを参照してください。
49
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
GNU Lesser General Public License 2.1
50
GNU Lesser General Public License 2.1
GNU LESSER GENERAL PUBLIC LICENSE
Version 2.1, February 1999
Copyright (C) 1991, 1999 Free Software Foundation, Inc.
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
[This is the first released version of the Lesser GPL. It also counts
as the successor of the GNU Library Public License, version 2, hence
the version number 2.1.]
Preamble
The licenses for most software are designed to take away your
freedom to share and change it. By contrast, the GNU General Public
Licenses are intended to guarantee your freedom to share and change
free software--to make sure the software is free for all its users.
This license, the Lesser General Public License, applies to some
specially designated software packages--typically libraries--of the
Free Software Foundation and other authors who decide to use it. You
can use it too, but we suggest you first think carefully about whether
this license or the ordinary General Public License is the better
strategy to use in any particular case, based on the explanations below.
When we speak of free software, we are referring to freedom of use,
not price. Our General Public Licenses are designed to make sure that
you have the freedom to distribute copies of free software (and charge
for this service if you wish); that you receive source code or can get
it if you want it; that you can change the software and use pieces of
it in new free programs; and that you are informed that you can do
these things.
To protect your rights, we need to make restrictions that forbid
distributors to deny you these rights or to ask you to surrender these
rights. These restrictions translate to certain responsibilities for
you if you distribute copies of the library or if you modify it.
For example, if you distribute copies of the library, whether gratis
or for a fee, you must give the recipients all the rights that we gave
you. You must make sure that they, too, receive or can get the source
code. If you link other code with the library, you must provide
complete object files to the recipients, so that they can relink them
with the library after making changes to the library and recompiling
it. And you must show them these terms so they know their rights.
We protect your rights with a two-step method: (1) we copyright the
library, and (2) we offer you this license, which gives you legal
permission to copy, distribute and/or modify the library.
To protect each distributor, we want to make it very clear that
there is no warranty for the free library. Also, if the library is
modified by someone else and passed on, the recipients should know
that what they have is not the original version, so that the original
author's reputation will not be affected by problems that might be
introduced by others.
Finally, software patents pose a constant threat to the existence of
any free program. We wish to make sure that a company cannot
51
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
effectively restrict the users of a free program by obtaining a
restrictive license from a patent holder. Therefore, we insist that
any patent license obtained for a version of the library must be
consistent with the full freedom of use specified in this license.
Most GNU software, including some libraries, is covered by the
ordinary GNU General Public License. This license, the GNU Lesser
General Public License, applies to certain designated libraries, and
is quite different from the ordinary General Public License. We use
this license for certain libraries in order to permit linking those
libraries into non-free programs.
When a program is linked with a library, whether statically or using
a shared library, the combination of the two is legally speaking a
combined work, a derivative of the original library. The ordinary
General Public License therefore permits such linking only if the
entire combination fits its criteria of freedom. The Lesser General
Public License permits more lax criteria for linking other code with
the library.
We call this license the "Lesser" General Public License because it
does Less to protect the user's freedom than the ordinary General
Public License. It also provides other free software developers Less
of an advantage over competing non-free programs. These disadvantages
are the reason we use the ordinary General Public License for many
libraries. However, the Lesser license provides advantages in certain
special circumstances.
For example, on rare occasions, there may be a special need to
encourage the widest possible use of a certain library, so that it becomes
a de-facto standard. To achieve this, non-free programs must be
allowed to use the library. A more frequent case is that a free
library does the same job as widely used non-free libraries. In this
case, there is little to gain by limiting the free library to free
software only, so we use the Lesser General Public License.
In other cases, permission to use a particular library in non-free
programs enables a greater number of people to use a large body of
free software. For example, permission to use the GNU C Library in
non-free programs enables many more people to use the whole GNU
operating system, as well as its variant, the GNU/Linux operating
system.
Although the Lesser General Public License is Less protective of the
users' freedom, it does ensure that the user of a program that is
linked with the Library has the freedom and the wherewithal to run
that program using a modified version of the Library.
The precise terms and conditions for copying, distribution and
modification follow. Pay close attention to the difference between a
"work based on the library" and a "work that uses the library". The
former contains code derived from the library, whereas the latter must
be combined with the library in order to run.
GNU LESSER GENERAL PUBLIC LICENSE
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
0. This License Agreement applies to any software library or other
program which contains a notice placed by the copyright holder or
other authorized party saying it may be distributed under the terms of
52
GNU Lesser General Public License 2.1
this Lesser General Public License (also called "this License").
Each licensee is addressed as "you".
A "library" means a collection of software functions and/or data
prepared so as to be conveniently linked with application programs
(which use some of those functions and data) to form executables.
The "Library", below, refers to any such software library or work
which has been distributed under these terms. A "work based on the
Library" means either the Library or any derivative work under
copyright law: that is to say, a work containing the Library or a
portion of it, either verbatim or with modifications and/or translated
straightforwardly into another language. (Hereinafter, translation is
included without limitation in the term "modification".)
"Source code" for a work means the preferred form of the work for
making modifications to it. For a library, complete source code means
all the source code for all modules it contains, plus any associated
interface definition files, plus the scripts used to control compilation
and installation of the library.
Activities other than copying, distribution and modification are not
covered by this License; they are outside its scope. The act of
running a program using the Library is not restricted, and output from
such a program is covered only if its contents constitute a work based
on the Library (independent of the use of the Library in a tool for
writing it). Whether that is true depends on what the Library does
and what the program that uses the Library does.
1. You may copy and distribute verbatim copies of the Library's
complete source code as you receive it, in any medium, provided that
you conspicuously and appropriately publish on each copy an
appropriate copyright notice and disclaimer of warranty; keep intact
all the notices that refer to this License and to the absence of any
warranty; and distribute a copy of this License along with the
Library.
You may charge a fee for the physical act of transferring a copy,
and you may at your option offer warranty protection in exchange for a
fee.
2. You may modify your copy or copies of the Library or any portion
of it, thus forming a work based on the Library, and copy and
distribute such modifications or work under the terms of Section 1
above, provided that you also meet all of these conditions:
a) The modified work must itself be a software library.
b) You must cause the files modified to carry prominent notices
stating that you changed the files and the date of any change.
c) You must cause the whole of the work to be licensed at no
charge to all third parties under the terms of this License.
d) If a facility in the modified Library refers to a function or a
table of data to be supplied by an application program that uses
the facility, other than as an argument passed when the facility
is invoked, then you must make a good faith effort to ensure that,
in the event an application does not supply such function or
table, the facility still operates, and performs whatever part of
53
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
its purpose remains meaningful.
(For example, a function in a library to compute square roots has
a purpose that is entirely well-defined independent of the
application. Therefore, Subsection 2d requires that any
application-supplied function or table used by this function must
be optional: if the application does not supply it, the square
root function must still compute square roots.)
These requirements apply to the modified work as a whole. If
identifiable sections of that work are not derived from the Library,
and can be reasonably considered independent and separate works in
themselves, then this License, and its terms, do not apply to those
sections when you distribute them as separate works. But when you
distribute the same sections as part of a whole which is a work based
on the Library, the distribution of the whole must be on the terms of
this License, whose permissions for other licensees extend to the
entire whole, and thus to each and every part regardless of who wrote
it.
Thus, it is not the intent of this section to claim rights or contest
your rights to work written entirely by you; rather, the intent is to
exercise the right to control the distribution of derivative or
collective works based on the Library.
In addition, mere aggregation of another work not based on the Library
with the Library (or with a work based on the Library) on a volume of
a storage or distribution medium does not bring the other work under
the scope of this License.
3. You may opt to apply the terms of the ordinary GNU General Public
License instead of this License to a given copy of the Library. To do
this, you must alter all the notices that refer to this License, so
that they refer to the ordinary GNU General Public License, version 2,
instead of to this License. (If a newer version than version 2 of the
ordinary GNU General Public License has appeared, then you can specify
that version instead if you wish.) Do not make any other change in
these notices.
Once this change is made in a given copy, it is irreversible for
that copy, so the ordinary GNU General Public License applies to all
subsequent copies and derivative works made from that copy.
This option is useful when you wish to copy part of the code of
the Library into a program that is not a library.
4. You may copy and distribute the Library (or a portion or
derivative of it, under Section 2) in object code or executable form
under the terms of Sections 1 and 2 above provided that you accompany
it with the complete corresponding machine-readable source code, which
must be distributed under the terms of Sections 1 and 2 above on a
medium customarily used for software interchange.
If distribution of object code is made by offering access to copy
from a designated place, then offering equivalent access to copy the
source code from the same place satisfies the requirement to
distribute the source code, even though third parties are not
compelled to copy the source along with the object code.
5. A program that contains no derivative of any portion of the
54
GNU Lesser General Public License 2.1
Library, but is designed to work with the Library by being compiled or
linked with it, is called a "work that uses the Library". Such a
work, in isolation, is not a derivative work of the Library, and
therefore falls outside the scope of this License.
However, linking a "work that uses the Library" with the Library
creates an executable that is a derivative of the Library (because it
contains portions of the Library), rather than a "work that uses the
library". The executable is therefore covered by this License.
Section 6 states terms for distribution of such executables.
When a "work that uses the Library" uses material from a header file
that is part of the Library, the object code for the work may be a
derivative work of the Library even though the source code is not.
Whether this is true is especially significant if the work can be
linked without the Library, or if the work is itself a library. The
threshold for this to be true is not precisely defined by law.
If such an object file uses only numerical parameters, data
structure layouts and accessors, and small macros and small inline
functions (ten lines or less in length), then the use of the object
file is unrestricted, regardless of whether it is legally a derivative
work. (Executables containing this object code plus portions of the
Library will still fall under Section 6.)
Otherwise, if the work is a derivative of the Library, you may
distribute the object code for the work under the terms of Section 6.
Any executables containing that work also fall under Section 6,
whether or not they are linked directly with the Library itself.
6. As an exception to the Sections above, you may also combine or
link a "work that uses the Library" with the Library to produce a
work containing portions of the Library, and distribute that work
under terms of your choice, provided that the terms permit
modification of the work for the customer's own use and reverse
engineering for debugging such modifications.
You must give prominent notice with each copy of the work that the
Library is used in it and that the Library and its use are covered by
this License. You must supply a copy of this License. If the work
during execution displays copyright notices, you must include the
copyright notice for the Library among them, as well as a reference
directing the user to the copy of this License. Also, you must do one
of these things:
a) Accompany the work with the complete corresponding
machine-readable source code for the Library including whatever
changes were used in the work (which must be distributed under
Sections 1 and 2 above); and, if the work is an executable linked
with the Library, with the complete machine-readable "work that
uses the Library", as object code and/or source code, so that the
user can modify the Library and then relink to produce a modified
executable containing the modified Library. (It is understood
that the user who changes the contents of definitions files in the
Library will not necessarily be able to recompile the application
to use the modified definitions.)
b) Use a suitable shared library mechanism for linking with the
Library. A suitable mechanism is one that (1) uses at run time a
copy of the library already present on the user's computer system,
55
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
rather than copying library functions into the executable, and (2)
will operate properly with a modified version of the library, if
the user installs one, as long as the modified version is
interface-compatible with the version that the work was made with.
c) Accompany the work with a written offer, valid for at
least three years, to give the same user the materials
specified in Subsection 6a, above, for a charge no more
than the cost of performing this distribution.
d) If distribution of the work is made by offering access to copy
from a designated place, offer equivalent access to copy the above
specified materials from the same place.
e) Verify that the user has already received a copy of these
materials or that you have already sent this user a copy.
For an executable, the required form of the "work that uses the
Library" must include any data and utility programs needed for
reproducing the executable from it. However, as a special exception,
the materials to be distributed need not include anything that is
normally distributed (in either source or binary form) with the major
components (compiler, kernel, and so on) of the operating system on
which the executable runs, unless that component itself accompanies
the executable.
It may happen that this requirement contradicts the license
restrictions of other proprietary libraries that do not normally
accompany the operating system. Such a contradiction means you cannot
use both them and the Library together in an executable that you
distribute.
7. You may place library facilities that are a work based on the
Library side-by-side in a single library together with other library
facilities not covered by this License, and distribute such a combined
library, provided that the separate distribution of the work based on
the Library and of the other library facilities is otherwise
permitted, and provided that you do these two things:
a) Accompany the combined library with a copy of the same work
based on the Library, uncombined with any other library
facilities. This must be distributed under the terms of the
Sections above.
b) Give prominent notice with the combined library of the fact
that part of it is a work based on the Library, and explaining
where to find the accompanying uncombined form of the same work.
8. You may not copy, modify, sublicense, link with, or distribute
the Library except as expressly provided under this License. Any
attempt otherwise to copy, modify, sublicense, link with, or
distribute the Library is void, and will automatically terminate your
rights under this License. However, parties who have received copies,
or rights, from you under this License will not have their licenses
terminated so long as such parties remain in full compliance.
9. You are not required to accept this License, since you have not
signed it. However, nothing else grants you permission to modify or
distribute the Library or its derivative works. These actions are
prohibited by law if you do not accept this License. Therefore, by
56
GNU Lesser General Public License 2.1
modifying or distributing the Library (or any work based on the
Library), you indicate your acceptance of this License to do so, and
all its terms and conditions for copying, distributing or modifying
the Library or works based on it.
10. Each time you redistribute the Library (or any work based on the
Library), the recipient automatically receives a license from the
original licensor to copy, distribute, link with or modify the Library
subject to these terms and conditions. You may not impose any further
restrictions on the recipients' exercise of the rights granted herein.
You are not responsible for enforcing compliance by third parties with
this License.
11. If, as a consequence of a court judgment or allegation of patent
infringement or for any other reason (not limited to patent issues),
conditions are imposed on you (whether by court order, agreement or
otherwise) that contradict the conditions of this License, they do not
excuse you from the conditions of this License. If you cannot
distribute so as to satisfy simultaneously your obligations under this
License and any other pertinent obligations, then as a consequence you
may not distribute the Library at all. For example, if a patent
license would not permit royalty-free redistribution of the Library by
all those who receive copies directly or indirectly through you, then
the only way you could satisfy both it and this License would be to
refrain entirely from distribution of the Library.
If any portion of this section is held invalid or unenforceable under any
particular circumstance, the balance of the section is intended to apply,
and the section as a whole is intended to apply in other circumstances.
It is not the purpose of this section to induce you to infringe any
patents or other property right claims or to contest validity of any
such claims; this section has the sole purpose of protecting the
integrity of the free software distribution system which is
implemented by public license practices. Many people have made
generous contributions to the wide range of software distributed
through that system in reliance on consistent application of that
system; it is up to the author/donor to decide if he or she is willing
to distribute software through any other system and a licensee cannot
impose that choice.
This section is intended to make thoroughly clear what is believed to
be a consequence of the rest of this License.
12. If the distribution and/or use of the Library is restricted in
certain countries either by patents or by copyrighted interfaces, the
original copyright holder who places the Library under this License may add
an explicit geographical distribution limitation excluding those countries,
so that distribution is permitted only in or among countries not thus
excluded. In such case, this License incorporates the limitation as if
written in the body of this License.
13. The Free Software Foundation may publish revised and/or new
versions of the Lesser General Public License from time to time.
Such new versions will be similar in spirit to the present version,
but may differ in detail to address new problems or concerns.
Each version is given a distinguishing version number. If the Library
specifies a version number of this License which applies to it and
"any later version", you have the option of following the terms and
57
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
conditions either of that version or of any later version published by
the Free Software Foundation. If the Library does not specify a
license version number, you may choose any version ever published by
the Free Software Foundation.
14. If you wish to incorporate parts of the Library into other free
programs whose distribution conditions are incompatible with these,
write to the author to ask for permission. For software which is
copyrighted by the Free Software Foundation, write to the Free
Software Foundation; we sometimes make exceptions for this. Our
decision will be guided by the two goals of preserving the free status
of all derivatives of our free software and of promoting the sharing
and reuse of software generally.
NO WARRANTY
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
DAMAGES.
END OF TERMS AND CONDITIONS
How to Apply These Terms to Your New Libraries
If you develop a new library, and you want it to be of the greatest
possible use to the public, we recommend making it free software that
everyone can redistribute and change. You can do so by permitting
redistribution under these terms (or, alternatively, under the terms of the
ordinary General Public License).
To apply these terms, attach the following notices to the library. It is
safest to attach them to the start of each source file to most effectively
convey the exclusion of warranty; and each file should have at least the
"copyright" line and a pointer to where the full notice is found.
<one line to give the library's name and a brief idea of what it does.>
Copyright (C) <year> <name of author>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
58
GNU Lesser General Public License 2.1
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
USA
Also add information on how to contact you by electronic and paper mail.
You should also get your employer (if you work as a programmer) or your
school, if any, to sign a "copyright disclaimer" for the library, if
necessary. Here is a sample; alter the names:
Yoyodyne, Inc., hereby disclaims all copyright interest in the
library `Frob' (a library for tweaking knobs) written by James Random Hacker.
<signature of Ty Coon>, 1 April 1990
Ty Coon, President of Vice
That's all there is to it!
59
JBoss Enterprise D ata Services 5 D ata Services クライアント開発者ガイド
改訂履歴
改訂 5.2.0-2.4 00
2013-10-31
Landmann Rüdiger [FAMILY
Given]
2012-07-18
T owns Anthony [FAMILY
Given]
Rebuild with publican 4.0.0
改訂 5.2.0-2
Rebuild for Publican 3.0
改訂 5.2.0-0
Mon Jun 27 2011
JBoss Enterprise SOA Platform 5.2 向けに更新
Le Sage David [FAMILY Given]
改訂 5.1.0-1
Mon May 23 2011
ODBC ドライバーの説明を更新
Le Sage David [FAMILY Given]
改訂 5.1.0-0
Fri Feb 18 2011
T eiid クライアント開発者ガイドより作成
Mison Darrin [FAMILY Given]
60