OracleConnectionオブジェクトは、Oracle Databaseへの接続を表します。
クラスの継承
System.Object
System.MarshalByRefObject
System.ComponentModel.Component
System.Data.Common.DbConnection(ADO.NET 2.0のみ)
Oracle.DataAccess.Client.OracleConnection
宣言
// ADO.NET 2.0: C# public sealed class OracleConnection : DbConnection, IDbConnection, ICloneable
// ADO.NET 1.x: C#
public sealed class OracleConnection : Component, IdbConnection, ICloneable
スレッド安全性
パブリック静的メソッドはスレッドセーフですが、インスタンス・メソッドではスレッド安全性は保証されません。
例
// C#
using System;
using System.Data;
using Oracle.DataAccess.Client;
class OracleConnectionSample
{
static void Main()
{
// Connect
string constr = "User Id=scott;Password=tiger;Data Source=oracle";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Execute a SQL SELECT
OracleCommand cmd = con.CreateCommand();
cmd.CommandText = "select * from emp";
OracleDataReader reader = cmd.ExecuteReader();
// Print all employee numbers
while (reader.Read())
Console.WriteLine(reader.GetInt32(0));
// Clean up
reader.Dispose();
cmd.Dispose();
con.Dispose();
}
}
要件
ネームスペース: Oracle.DataAccess.Client
アセンブリ: Oracle.DataAccess.dll
Microsoft .NET Frameworkバージョン: 1.xまたは2.0
OracleConnectionメンバーは、次の表にリストされています。
OracleConnectionコンストラクタ
OracleConnectionコンストラクタのリストを、表5-17に示します。
OracleConnection静的プロパティ
OracleConnection静的プロパティのリストを、表5-19に示します。
OracleConnection静的メソッド
OracleConnection静的メソッドのリストを、表5-19にリストします。
表5-19 OracleConnection静的メソッド
| メソッド | 説明 |
|---|---|
|
|
|
|
|
指定された .NETストアド・プロシージャではサポートされません |
|
|
すべての接続プールからすべての接続を消去します .NETストアド・プロシージャではサポートされません |
OracleConnectionプロパティ
OracleConnectionプロパティのリストを、表5-20に示します。
表5-20 OracleConnectionプロパティ
| 名前 | 説明 |
|---|---|
|
|
接続のクライアント識別子を指定します |
|
Oracle Databaseへの接続に使用される接続情報を指定します |
|
|
|
|
|
|
|
|
|
サポート対象外 |
|
|
接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミングを指定します |
|
|
|
|
|
|
|
接続の現在の状態を指定します |
OracleConnectionパブリック・メソッド
OracleConnectionパブリック・メソッドのリストを、表5-21に示します。
表5-21 OracleConnectionパブリック・メソッド
| パブリック・メソッド | 説明 |
|---|---|
|
ローカル・トランザクションを開始します(オーバーロード) .NETストアド・プロシージャではサポートされません |
|
|
サポート対象外 |
|
|
|
.NETストアド・プロシージャではサポートされません |
|
|
データベース接続をクローズします |
|
|
|
|
|
|
|
|
|
|
|
アプリケーションによって、指定された分散トランザクションに明示的に登録できるようにします .NETストアド・プロシージャではサポートされません |
|
|
アプリケーションによって、指定された分散トランザクションに登録できるようにします ADO.NET 2.0準拠のODP.NETでのみサポート .NETストアド・プロシージャではサポートされません |
|
|
|
|
|
|
|
|
|
|
|
ADO.NET 2.0準拠のODP.NETでのみサポート |
|
セッションのグローバリゼーションの設定を表す |
|
|
|
|
|
|
|
|
|
|
|
新規パスワードで新規接続をオープンします .NETストアド・プロシージャではサポートされません |
|
|
|
文キャッシングが有効な場合、データベースでオープンしているすべてのカーソルをクローズし、文キャッシュをフラッシュします |
|
セッションのグローバリゼーションの設定を |
|
|
|
|
OracleConnectionイベント
OracleConnectionイベントのリストを、表5-22に示します。
表5-22 OracleConnectionイベント
| イベント名 | 説明 |
|---|---|
|
|
|
|
Oracleフェイルオーバーが発生するときにトリガーされるイベント .NETストアド・プロシージャではサポートされません |
|
|
すべてのメッセージにトリガーされるイベントまたはデータベースにより送信される警告 |
|
|
接続の状態が変更されたときにトリガーされるイベント |
OracleConnectionコンストラクタはOracleConnectionクラスの新規インスタンスをインスタンス化します。
オーバーロード・リスト:
このコンストラクタは、デフォルト・プロパティ値を使用してOracleConnectionクラスの新規インスタンスをインスタンス化します。
このコンストラクタは、指定された接続文字列とともにOracleConnectionクラスの新規インスタンスをインスタンス化します。
このコンストラクタは、デフォルト・プロパティ値を使用してOracleConnectionクラスの新規インスタンスをインスタンス化します。
宣言
// C# public OracleConnection();
備考
OracleConnectionのプロパティは次のデフォルト値に設定されます。
ConnectionString = 空の文字列
ConnectionTimeout = 15(暗黙的なデータベース接続にはデフォルト値の0が使用されます)
DataSource = 空の文字列
ServerVersion = 空の文字列
このコンストラクタは、指定された接続文字列とともにOracleConnectionクラスの新規インスタンスをインスタンス化します。
宣言
// C#
public OracleConnection(String connectionString);
パラメータ
connectionString
接続情報は、Oracle Databaseへの接続に使用されます。
備考
ConnectionStringプロパティは、指定されたconnectionStringに設定されます。ConnectionStringプロパティは解析され、無効な接続文字列属性または属性値が含まれる場合は、例外がスローされます。
OracleConnectionオブジェクトのプロパティは、接続文字列により設定されない場合は、次の値をデフォルトとします。
ConnectionString = 空の文字列
ConnectionTimeout = 15(暗黙的なデータベース接続にはデフォルト値の0が使用されます)
DataSource = 空の文字列
ServerVersion = 空の文字列
OracleConnection静的プロパティのリストを、表5-23にリストします。
このプロパティは、暗黙的なデータベース接続が使用できるかどうかを示します。
宣言
// C#
public static bool IsAvailable {get;}
プロパティ値
暗黙的なデータベース接続が使用できる場合はtrueを戻します。
備考
暗黙的なデータベース接続の可用性は、実行時にこの静的プロパティを使用して確認できます。Oracle Data Provider for .NETが.NETストアド・プロシージャ内で使用されている場合、このプロパティは常にtrueを戻します。それ以外の場合は、falseが戻されます。
暗黙的なデータベース接続を表すOracleConnectionオブジェクトを.NETストアド・プロシージャで取得するには、OracleConnectionオブジェクトのConnectionStringプロパティを"context connection=true"に設定し、Openメソッドを起動します。
明示的なユーザー接続に使用できるすべての機能を暗黙的なデータベース接続に使用できるわけではないことに注意してください。詳細は、「暗黙的データベース接続」を参照してください。
例
// C# (Library/DLL)
using System;
using Oracle.DataAccess.Client;
public class IsAvailableSample
{
static void MyStoredProcedure()
{
OracleConnection con = new OracleConnection();
if (OracleConnection.IsAvailable)
{
// This function is invoked as a stored procedure
// Obtain the implicit database connection by setting
// "context connection=true" in the connection string
con.ConnectionString = "context connection=true";
}
else
{
// This function is not invoked as a stored procedure
// Set the connection string for a normal client connection
con.ConnectionString = "user id=scott;password=tiger;data source=oracle";
}
con.Open();
Console.WriteLine("connected!");
}
}
OracleConnection静的メソッドのリストを、表5-24にリストします。
表5-24 OracleConnection静的メソッド
| メソッド | 説明 |
|---|---|
|
|
|
|
|
指定された .NETストアド・プロシージャではサポートされません |
|
|
すべての接続プールからすべての接続を消去します .NETストアド・プロシージャではサポートされません |
このメソッドは、指定されたOracleConnectionオブジェクトに関連付けられている接続プールを消去します。
宣言
// C# public static void ClearPool(OracleConnection connection);
備考
このメソッドが起動されると、すべてのアイドル接続がクローズされてプールから解放されます。 現在使用中の接続は、プールに戻されるまで廃棄されません。
ClearPoolメソッドは、有効な接続を作成できるとき(つまり、データベースが稼動状態で接続できるとき)にのみ起動してください。 そうしないと、停止中のデータベース・インスタンスへの無効な接続のみがClearPoolメソッドで作成される場合があります。 有効なデータベース接続がある場合にClearPoolを起動すると、使用可能な接続を使用して接続プールが作成されます。したがって、接続要求はこのメソッドの起動後も正常に処理されます。このメソッドの起動後に作成される接続は、もう一度起動を実行しないかぎり消去されません。
このメソッドは、ConnectionStringが正しく設定されていれば、接続をオープンする前後いずれでもOracleConnectionオブジェクトに対して起動できます。
例外
InvalidOperationException: 接続プールが見つからないか、指定された接続文字列が無効です。
例
// C#
// Sample demonstrating the use of ClearPool API in OracleConnection class
using System;
using Oracle.DataAccess.Client;
class ClearPoolSample
{
static void Main()
{
Console.WriteLine("Running ClearPool sample..." );
// Set the connection string
string strConn = "User Id=scott;Password=tiger;Data Source=oracle;" +
"Min pool size=5;";
OracleConnection conn = new OracleConnection(strConn);
// Open the connection
conn.Open();
// Clears the connection pool associated with connection 'conn'
OracleConnection.ClearPool (conn);
// This connection will be placed back into the pool
conn.Close ();
// Open the connection again to create additional connections in the pool
conn.Open();
// Create a new connection object
OracleConnection connNew = new OracleConnection(strConn);
// Clears the pool associated with Connection 'connNew'
// Since the same connection string is set for both the connections,
// connNew and conn, they will be part of the same connection pool.
// We need not do an Open() on the connection object before calling
// ClearPool
OracleConnection.ClearPool (connNew);
// cleanup
conn.Close();
Console.WriteLine("Done!");
}
}
このメソッドは、すべての接続プールからすべての接続を消去します。
宣言
// C# public static void ClearAllPools();
備考(Oracle.DataAccess.Clientのみ)
この呼出しは、アプリケーション用に作成されたすべての接続プールに対するClearPoolの呼出しと類似しています。
例外
InvalidOperationException: アプリケーションに対する接続プールが見つかりません。
例
// C#
// Sample demonstrating the use of ClearAllPools API in OracleConnection class
using System;
using Oracle.DataAccess.Client;
class ClearAllPoolsSample
{
static void Main()
{
Console.WriteLine("Running ClearAllPools sample..." );
// Set the connection string
string strConn = "User Id=scott;Password=tiger;Data Source=oracle;" +
"Min pool size=5;";
OracleConnection conn = new OracleConnection(strConn);
// Create another connection object with a different connection string
string strConnNew = "User Id=scott;Password=tiger;Data Source=oracle;";
OracleConnection connNew = new OracleConnection(strConnNew);
// Open the connections. Separate pools are created for conn and connNew
conn.Open();
connNew.Open();
// Clears the pools associated with conn and connNew
OracleConnection.ClearAllPools ();
// cleanup
conn.Close();
connNew.Close();
Console.WriteLine("Done!");
}
}
OracleConnectionプロパティのリストを、表5-25に示します。
表5-25 OracleConnectionプロパティ
| 名前 | 説明 |
|---|---|
|
|
接続のクライアント識別子を指定します |
|
Oracle Databaseへの接続に使用される接続情報を指定します |
|
|
|
|
|
|
|
|
|
サポート対象外 |
|
|
接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミングを指定します |
|
|
|
|
|
|
|
接続の現在の状態を指定します |
このプロパティでは、接続のクライアント識別子を指定します。
宣言
// C#
public string ClientId {set;}
プロパティ値
クライアント識別子として使用される文字列
備考
デフォルト値はnullです。
ClientIdをnullに設定すると、接続のクライアント識別子がリセットされます。ClientIdを空の文字列に設定すると、接続のクライアント識別子が空の文字列に設定されます。OracleConnectionオブジェクトでCloseメソッドがコールされると、ClientIdはnullに設定されます。
ClientIdプロパティを使用すると、アプリケーションでODP.NETを使用する各データベース・セッションに対してアプリケーション・コンテキスト内にクライアント識別子を設定できます。これによりODP.NET開発者は、Oracle Virtual Private Database(VPD)をより簡単に構成できるようになります。
|
参照: |
このプロパティは、Oracle Databaseへの接続に使用される接続情報を指定します。
宣言
// ADO.NET 2.0: C#
public override string ConnectionString{get; set;}
// ADO.NET: 1.x C#
public string ConnectionString{get; set;}
プロパティ値
接続文字列がコンストラクタを介して指定される場合、このプロパティはその文字列に設定されます。
実装
IDbConnection
例外
ArgumentException: 無効な構文が接続文字列に指定されました。
InvalidOperationException: ConnectionStringが接続がオープン中に設定されました。
備考
デフォルト値が空の文字列です。
ConnectionStringは、セミコロンで区切られた属性名と値のペアにする必要があります。次に例を示します。
"User Id=scott;password=tiger;data source=oracle"
ConnectionStringの形式が正しくない場合、例外がスローされます。二重引用符で囲まれていない場合、すべてのスペースは無視されます。
ConnectionStringプロパティが設定されている場合、OracleConnectionオブジェクトはすぐに文字列のエラーを解析します。ArgumentExceptionは、ConnectionStringに無効な属性または無効な値が含まれている場合に、スローされます。User Id、Password、Proxy User Id、Proxy Password、およびData Source(提供されている場合)の属性値は、Openメソッドがコールされるまで検証されません。
接続はクローズして、ConnectionStringプロパティに設定する必要があります。ConnectionStringプロパティがリセットされる場合、事前に設定された値は、新しい値が適用される前にそれぞれのデフォルト値に再初期化されます。
ODP.NET 11.1以降では、パスワードおよびプロキシ・パスワード接続文字列属性値の大/小文字が区別されます。 そのため、接続文字列に指定された大/小文字のまま、認証用データベースに渡されます。 そのため、パスワードの大/小文字を区別するようにデータベースが構成されている場合は、正しい大/小文字を使用してパスワードを渡す必要があります。
接続文字列属性が2回以上設定されている場合、最新の設定が実行され、例外はスローされません。
ブール接続文字列属性は、true、false、yesまたはnoのいずれかに設定できます。
備考(.NETストアド・プロシージャ)
暗黙的なデータベース接続を表すOracleConnectionオブジェクトを.NETストアド・プロシージャで取得するには、OracleConnectionオブジェクトのConnectionStringプロパティを"context connection=true"に設定し、Openメソッドを起動します。"context connection"がtrueに設定されている場合、その他の接続文字列属性を一緒に使用することはできません。
サポートされている接続文字列属性
表5-26に、サポートされている接続文字列の属性リストを示します。
表5-26 サポートされている接続文字列の属性
| 接続文字列属性 | 説明 | デフォルト値 |
|---|---|---|
|
|
接続の最大存続期間(秒)。 この属性は、接続の存続期間を秒単位で指定します。 |
|
|
|
プールから使用可能な接続を待機する最大時間(秒)。 この属性は、 この属性値はプールされた接続要求に対して有効となりますが、新規接続要求に対しては有効にはなりません。 (.NETストアド・プロシージャにおける暗黙的なデータベース接続のデフォルト値は |
|
|
|
暗黙的なデータベース接続は、.NETストアド・プロシージャ内からのみ取得できます。 .NETストアド・プロシージャでのみサポートされています。 |
|
|
|
接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミング。 |
空の文字列 |
|
|
管理者権限 この接続文字列属性は、属性値として |
空の文字列 |
|
|
未使用の確立済接続量が過剰となり、クローズされる接続数。 |
|
|
|
この接続文字列の属性は、プール・レギュレータが定期的なチェックを行う場合、クローズされる未使用の最大接続数を制御します。このレギュレータ・スレッドは3分ごとに生成され、プールされた接続が使用されていない場合、その接続の |
|
|
|
COM+トランザクションまたは この属性が |
|
|
|
RACサービス、サービス・メンバーまたはノードが停止した場合、ODP.NET接続プールが予防的にプールから接続を削除できるようにします。 この機能は、 この属性は、 |
|
|
|
ODP.NET接続プールを使用して、ロード・バランス・アドバイザおよびサービス目標に基づき、RACインスタンス間の作業要求のバランスを調整できます。 この機能は、 この属性は、 |
|
|
|
プール内のすべての接続が使用された場合に作成される新しい接続の数。 この接続文字列属性は、プールされた接続が要求されたときに確立される新規接続の数を決定しますが、未使用の接続は使用不可であり、 |
|
|
|
プール内の接続の最大数。 この属性は、 |
|
|
|
メタデータ情報をキャッシュします。 この属性は、実行された問合せのメタデータ情報を、性能向上のためにキャッシュするかどうかを示します。 |
|
|
|
プール内の接続の最小数。 この属性は、プールのすべての存続期間中、プールにより保持される接続の最少数を指定します。接続文字列でこの属性を変更するだけでは、現在すでに存在するプールの |
|
|
|
この属性はOracleユーザーのパスワードを指定します。 |
空の文字列 |
|
|
接続文字列でのパスワード検索。 この属性が |
|
|
|
接続プーリング。 この属性は、接続プーリングを使用する必要があるかどうかを指定します。プールは、属性値が一致するアルゴリズムを使用して作成されます。つまり、接続文字列内で単にスペースの数が異なる接続文字列は、同じプールを使用することを意味します。一方の接続文字列では属性をデフォルト値に設定し、もう一方の接続文字列でその属性を設定しないという点を除いて、2つの接続文字列が一致する場合、両方の要求とも同じプールから接続を取得します。この属性は、 |
|
|
|
プロキシ・ユーザーのユーザー名。 この接続文字列属性は、 |
空の文字列 |
|
|
プロキシ・ユーザーがオペレーティング・システム認証を使用してOracle Databaseに接続するには、 |
|
|
|
プロキシ・ユーザーのパスワード。 この接続文字列属性は、中間層のユーザーまたはプロキシ・ユーザーのパスワードを指定します。このユーザーは、 二重引用符によりこの属性値が囲まれている場合、この場合の属性値は保持されます。 |
空の文字列 |
|
|
接続がプールに戻るときの文キャッシュの消去。 文キャッシングが有効な場合、この属性を |
|
|
|
文キャッシュを有効にして、キャッシュ・サイズ、つまりキャッシュ可能な文の最大数のサイズを設定します。 文キャッシングはゼロより大きい値で可能で、キャッシュ・サイズはその値に設定されます。この値は、 |
10 |
|
|
Oracleユーザー名。 この属性は、Oracleユーザー名を指定します。二重引用符によりこの属性値が囲まれている場合、この場合の属性値は保持されます。 ユーザーがオペレーティング・システム認証を使用してOracle Databaseに接続するには、 |
空の文字列 |
|
|
プールを使用している接続の検証。 検証により、各接続に対してデータベースにラウンドトリップが発生します。このため、必要な場合のみ使用してください。 |
|
このプロパティは、Openメソッドが要求を終了する前にプールされた接続の取得に要する最大時間を示します。
宣言
// ADO.NET 2.0: C#
public override int ConnectionTimeout {get;}
// ADO.NET 1.x: C#
public int ConnectionTimeout {get;}
プロパティ値
プールされた接続要求に対する有効な最大時間(秒)
実装
IDbConnection
備考
このプロパティは、ConnectionString属性のConnection TimeOutを使用して設定されている接続タイムアウトを示します。
このプロパティは読取り専用です。
備考(.NETストアド・プロシージャ)
アプリケーションによって指定された接続文字列がなく、暗黙的なデータベースでの接続が常に使用可能であるため、このプロパティは0に設定されます。
このプロパティは、サポートされていません。
宣言
// ADO.NET 2.0: C#
public override string Database {get;}
// ADO.NET 1.x: C#
public string Database {get;}
プロパティ値
文字列
実装
IDbConnection.Database
備考
このプロパティは、サポートされていません。これは常に空の文字列を戻します。
このプロパティは、接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミングを指定します
宣言
// ADO.NET 2.0: C#
public override string DataSource {get;}
// ADO.NET 1.x: C#
public string DataSource {get;}
プロパティ値
接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミング。
備考(.NETストアド・プロシージャ)
暗黙的なデータベース接続の場合、このプロパティの値は常に空の文字列です。
このプロパティは、OracleConnectionが接続を確立するOracle Databaseのバージョン番号を指定します。
宣言
// ADO.NET 2.0: C#
public override string ServerVersion {get;}
// ADO.NET 1.x: C#
public string ServerVersion {get;}
プロパティ値
Oracle Databaseのバージョン
例外
InvalidOperationException: 接続がクローズされています。
備考
デフォルトは空の文字列です。
このプロパティは、接続の現在の状態を指定します。
宣言
// ADO.NET 2.0: C#
public override ConnectionState State {get;}
// ADO.NET 1.x: C#
public ConnectionState State {get;}
プロパティ値
接続のConnectionState
実装
IDbConnection
備考
ODP.NETでは、このプロパティに対してConnectionState.ClosedおよびConnectionState.Openがサポートされています。デフォルト値は、ConnectionState.Closedです。
OracleConnectionパブリック・メソッドのリストを、表5-27に示します。
表5-27 OracleConnectionパブリック・メソッド
| パブリック・メソッド | 説明 |
|---|---|
|
ローカル・トランザクションを開始します(オーバーロード) .NETストアド・プロシージャではサポートされません |
|
|
サポート対象外 |
|
|
|
.NETストアド・プロシージャではサポートされません |
|
|
データベース接続をクローズします |
|
|
|
|
|
|
|
|
|
|
|
アプリケーションによって、指定された分散トランザクションに明示的に登録できるようにします .NETストアド・プロシージャではサポートされません |
|
|
アプリケーションによって、指定された分散トランザクションに登録できるようにします ADO.NET 2.0準拠のODP.NETでのみサポート .NETストアド・プロシージャではサポートされません |
|
|
|
|
|
|
|
|
|
|
|
ADO.NET 2.0準拠のODP.NETでのみサポート |
|
セッションのグローバリゼーションの設定を表す |
|
|
|
|
|
|
|
|
|
|
|
新規パスワードで新規接続をオープンします .NETストアド・プロシージャではサポートされません |
|
|
|
文キャッシングが有効な場合、データベースでオープンしているすべてのカーソルをクローズし、文キャッシュをフラッシュします |
|
セッションのグローバリゼーションの設定を |
|
|
|
|
BeginTransactionメソッドは、ローカル・トランザクションを開始します。
オーバーロード・リスト
このメソッドは、ローカル・トランザクションを開始します。
BeginTransaction(IsolationLevel)
このメソッドは、ローカル・トランザクションを指定された分離レベルで開始します。
このメソッドは、ローカル・トランザクションを開始します。
宣言
// C# public OracleTransaction BeginTransaction();
戻り値
OracleTransactionオブジェクトは、新規トランザクションを表します。
実装
IDbConnection
例外
InvalidOperationException: トランザクションはすでに開始されています。
備考
トランザクションは、分離レベルで作成され、IsolationLevel.ReadCommittedのデフォルト値に設定されます。トランザクションに関連するすべての後続の操作は、戻されたOracleTransactionオブジェクトで実行する必要があります。
備考(.NETストアド・プロシージャ)
このメソッドを使用すると、未サポートの例外が発生します。
このメソッドは、ローカル・トランザクションを指定された分離レベルで開始します。
宣言
// C#
public OracleTransaction BeginTransaction(IsolationLevel isolationLevel);
パラメータ
isolationLevel
新規トランザクションの分離レベル
戻り値
OracleTransactionオブジェクトは、新規トランザクションを表します。
実装
IDbConnection
例外
InvalidOperationException: トランザクションはすでに開始されています。
ArgumentException: 指定したisolationLevel値が無効です。
備考
次の2つの分離レベルがサポートされています。
IsolationLevel.ReadCommitted
IsolationLevel.Serializable
他の分離レベルを要求すると、例外が発生します。
備考(.NETストアド・プロシージャ)
このメソッドを使用すると、未サポートの例外が発生します。
例
// C#
using System;
using System.Data;
using Oracle.DataAccess.Client;
class BeginTransactionSample
{
static void Main()
{
string constr = "User Id=scott;Password=tiger;Data Source=oracle";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Create an OracleCommand object using the connection object
OracleCommand cmd = con.CreateCommand();
// Start a transaction
OracleTransaction txn = con.BeginTransaction(IsolationLevel.ReadCommitted);
// Update EMP table
cmd.CommandText = "update emp set sal = sal + 100";
cmd.ExecuteNonQuery();
// Rollback transaction
txn.Rollback();
Console.WriteLine("Transaction rolledback");
// Clean up
txn.Dispose();
cmd.Dispose();
con.Dispose();
}
}
このメソッドは、サポートされていません。
宣言
// ADO.NET 2.0: C#
public override void ChangeDatabase(string databaseName);
// ADO.NET 1.x: C# public void ChangeDatabase(string databaseName);
パラメータ
databaseName
現行のデータベース名を置き換えるデータベースの名前
実装
IDbConnection.ChangeDatabase
例外
NotSupportedException: メソッドはサポートされていません。
備考
このメソッドはサポートされておらず、起動されるとNotSupportedExceptionをスローします。
このメソッドは、OracleConnectionオブジェクトのコピーを作成します。
宣言
// C# public object Clone();
戻り値
OracleConnectionオブジェクト
実装
ICloneable
備考
複製されたオブジェクトのプロパティ値は、複製元のオブジェクトのプロパティ値と同じです。
備考(.NETストアド・プロシージャ)
このメソッドは、暗黙的なデータベース接続ではサポートされていません。
例
// C#
using System;
using Oracle.DataAccess.Client;
class CloneSample
{
static void Main()
{
string constr = "User Id=scott;Password=tiger;Data Source=oracle";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Need a proper casting for the return value when cloned
OracleConnection clonedCon = (OracleConnection)con.Clone();
// Cloned connection is always closed, regardless of its source,
// But the connection string should be identical
clonedCon.Open();
if (clonedCon.ConnectionString.Equals(con.ConnectionString))
Console.WriteLine("The connection strings are the same.");
else
Console.WriteLine("The connection strings are different.");
// Close and Dispose OracleConnection object
clonedCon.Dispose();
}
}
このメソッドは、データベースへの接続をクローズします。
宣言
// ADO.NET 2.0: C# public override void Close();
// ADO.NET 1.x: C#
public void Close();
実装
IDbConnection
備考
次を実行します。
すべての保留中のトランザクションをロール・バックします。
接続プーリングが有効な場合、接続を接続プールに配置します。接続プーリングが有効な場合でも、接続が接続文字列に指定された接続存続期間を超える場合、その接続はクローズできます。接続プーリングが無効な場合、接続はクローズされます。
データベースへの接続をクローズします。
接続は、Open()を使用して再オープンできます。
このメソッドは、OracleConnectionオブジェクトに関連付けられたOracleCommandオブジェクトを作成して戻します。
宣言
// C# public OracleCommand CreateCommand();
戻り値
OracleCommandオブジェクト
実装
IDbConnection
例
// C#
using System;
using System.Data;
using Oracle.DataAccess.Client;
class CreateCommandSample
{
static void Main()
{
// Connect
string constr = "User Id=scott;Password=tiger;Data Source=oracle";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Execute a SQL SELECT
OracleCommand cmd = con.CreateCommand();
cmd.CommandText = "select * from emp";
OracleDataReader reader = cmd.ExecuteReader();
// Print all employee numbers
while (reader.Read())
Console.WriteLine(reader.GetInt32(0));
// Clean up
reader.Dispose();
cmd.Dispose();
con.Dispose();
}
}
このメソッドにより、アプリケーションは接続がオープンされた後に特定の分散トランザクションに明示的に登録できます。
宣言
// C#
public void EnlistDistributedTransaction(ITransaction transaction);
パラメータ
transaction
ITransactionインタフェース
例外
InvalidOperationException - 接続がローカル・トランザクションの一部であるか、または接続がクローズされています。
備考
EnlistDistributedTransactionにより、メソッドに渡された特定のトランザクションにオブジェクトを登録できます。ITransactionインタフェースは、分散トランザクションを開始したコンポーネント内でContexUtil.Transactionプロパティに(ITransaction)キャストを適用することで取得できます。
このメソッドを呼び出す前に接続がオープンされている必要があります。そうしないとInvalidOperationExceptionがスローされます。
接続が、分散トランザクションに登録を試みている最中に暗黙的または明示的に開始されたローカル・トランザクションの一部である場合、ローカル・トランザクションはロールバックされ、例外がスローされます。
デフォルトでは、メソッド・レベルのAutoComplete宣言が設定されていないかぎり、分散トランザクションはロールバックされます。
ITranasctionに対してコミットを起動すると例外が発生します。
ITranasctionメソッドに対してロールバックを起動し、同一分散トランザクションに対してContextUtil.SetCompleteを呼び出すと、例外が発生します。
備考(.NETストアド・プロシージャ)
このメソッドを使用すると、未サポートの例外が発生します。
例
アプリケーション:
// C#
/* This is the class that will utilize the Enterprise Services
component. This module needs to be built as an executable.
The Enterprise Services Component DLL must be built first
before building this module.
In addition, the DLL needs to be referenced appropriately
when building this application.
*/
using System;
using System.EnterpriseServices;
using DistribTxnSample;
class DistribTxnSample_App
{
static void Main()
{
DistribTxnSample_Comp comp = new DistribTxnSample_Comp();
comp.DoWork();
}
}
コンポーネント:
// C#
/* This module needs to be
1) built as a component DLL/Library
2) built with a strong name
This library must be built first before the application is built.
*/
using System;
using System.Data;
using Oracle.DataAccess.Client;
using System.EnterpriseServices;
namespace DistribTxnSample
{
[Transaction(TransactionOption.RequiresNew)]
public class DistribTxnSample_Comp : ServicedComponent
{
public void DoWork()
{
string constr =
"User Id=scott;Password=tiger;Data Source=oracle;enlist=false";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Enlist in a distrubuted transaction
con.EnlistDistributedTransaction((ITransaction)ContextUtil.Transaction);
// Update EMP table
OracleCommand cmd = con.CreateCommand();
cmd.CommandText = "UPDATE emp set sal = sal + .01";
cmd.ExecuteNonQuery();
// Commit
ContextUtil.SetComplete();
// Dispose OracleConnection object
con.Dispose();
}
}
}
このメソッドは、指定されたトランザクションに接続を登録します。
ADO.NET 2.0準拠のODP.NETでのみサポート
宣言
// C#
public override void EnlistTransaction(Transaction transaction)
パラメータ
transaction
System.Transactions.Transactionオブジェクト
例外
InvalidOperationException - 接続がローカル・トランザクションの一部であるか、または接続がクローズされています。
備考
このメソッドを起動すると、指定されたトランザクション・パラメータにより指定された分散トランザクションに接続が即時登録されます。
OracleConnectionが、前に起動したEnlistTransactionメソッドを完了していない分散トランザクションと関連付けられたままの場合、このメソッドの呼出しにより例外がスローされます。
一般に、分散トランザクションでの登録が正常に行われるためには、Openメソッドを起動する前に"enlist"接続文字列属性を"true"または"dynamic"のいずれかに設定する必要があります。"enlist"接続文字列属性を"true"に設定すると、接続がトランザクション・コンテキスト内にあれば、Openメソッドが呼び出されたときに暗黙的にその接続が登録されます。"dynamic"に設定すると、EnlistTransactionまたはEnlistDistributedTransactionメソッドが呼び出されたときに接続を動的に分散トランザクションに登録できます。"enlist"属性を"false"に設定するのは、接続が分散トランザクションに登録されることがない場合のみです。
GetSchemaメソッドは、OracleConnectionのデータ・ソースのスキーマ情報を戻します。
ADO.NET 2.0準拠のODP.NETでのみサポート
オーバーロード・リスト
このメソッドは、OracleConnectionのデータ・ソースのスキーマ情報を戻します。
GetSchema (string collectionName)
このメソッドは、コレクション名に指定された文字列を使用してOracleConnectionのデータ・ソースのスキーマ情報を戻します。
GetSchema (string collectionName, string[] restrictions)
このメソッドは、コレクション名に指定された文字列および制限値に指定された文字列配列を使用してOracleConnectionのデータ・ソースのスキーマ情報を戻します。
このメソッドは、OracleConnectionのデータ・ソースのスキーマ情報を戻します。
宣言
// ADO.NET 2.0: C# public override DataTable GetSchema();
戻り値
DataTableオブジェクト
例外
InvalidOperationException: 接続がクローズされています。
備考
このメソッドは、データベースから取得可能な各メタデータ・コレクションに対する行を含んだDataTableオブジェクトを戻します。
このメソッドは、GetSchema(String)メソッドの使用時にString値"MetaDataCollections"を指定することに相当します。
例
// C#
using System;
using System.Data;
using System.Data.Common;
using Oracle.DataAccess.Client;
class GetSchemaSample
{
static void Main(string[] args)
{
string constr = "User Id=scott; Password=tiger; Data Source=oracle;";
string ProviderName = "Oracle.DataAccess.Client";
DbProviderFactory factory = DbProviderFactories.GetFactory(ProviderName);
using (DbConnection conn = factory.CreateConnection())
{
try
{
conn.ConnectionString = constr;
conn.Open();
//Get all the schema collections and write to an XML file.
//The XML file name is Oracle.DataAccess.Client_Schema.xml
DataTable dtSchema = conn.GetSchema();
dtSchema.WriteXml(ProviderName + "_Schema.xml");
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
Console.WriteLine(ex.StackTrace);
}
}
}
}
このメソッドは、コレクション名に指定された文字列を使用してOracleConnectionのデータ・ソースのスキーマ情報を戻します。
宣言
// ADO.NET 2.0: C#
public override DataTable GetSchema (string collectionName);
パラメータ
collectionName
メタデータを必要とするコレクションの名前
戻り値
DataTableオブジェクト
例外
ArgumentException: 要求されたコレクションが定義されていません。
InvalidOperationException: 接続がクローズされています。
InvalidOperationException: 要求されたコレクションが、現行バージョンのOracle Databaseでサポートされていません。
InvalidOperationException: 要求されたコレクションに対して移入文字列が指定されていません。
例
// C#
using System;
using System.Data;
using System.Data.Common;
using Oracle.DataAccess.Client;
class GetSchemaSample
{
static void Main(string[] args)
{
string constr = "User Id=scott; Password=tiger; Data Source=oracle;";
string ProviderName = "Oracle.DataAccess.Client";
DbProviderFactory factory = DbProviderFactories.GetFactory(ProviderName);
using (DbConnection conn = factory.CreateConnection())
{
try
{
conn.ConnectionString = constr;
conn.Open();
//Get MetaDataCollections and write to an XML file.
//This is equivalent to GetSchema()
DataTable dtMetadata =
conn.GetSchema(DbMetaDataCollectionNames.MetaDataCollections);
dtMetadata.WriteXml(ProviderName + "_MetaDataCollections.xml");
//Get Restrictions and write to an XML file.
DataTable dtRestrictions =
conn.GetSchema(DbMetaDataCollectionNames.Restrictions);
dtRestrictions.WriteXml(ProviderName + "_Restrictions.xml");
//Get DataSourceInformation and write to an XML file.
DataTable dtDataSrcInfo =
conn.GetSchema(DbMetaDataCollectionNames.DataSourceInformation);
dtDataSrcInfo.WriteXml(ProviderName + "_DataSourceInformation.xml");
//data types and write to an XML file.
DataTable dtDataTypes =
conn.GetSchema(DbMetaDataCollectionNames.DataTypes);
dtDataTypes.WriteXml(ProviderName + "_DataTypes.xml");
//Get ReservedWords and write to an XML file.
DataTable dtReservedWords =
conn.GetSchema(DbMetaDataCollectionNames.ReservedWords);
dtReservedWords.WriteXml(ProviderName + "_ReservedWords.xml");
//Get all the tables and write to an XML file.
DataTable dtTables = conn.GetSchema("Tables");
dtTables.WriteXml(ProviderName + "_Tables.xml");
//Get all the views and write to an XML file.
DataTable dtViews = conn.GetSchema("Views");
dtViews.WriteXml(ProviderName + "_Views.xml");
//Get all the columns and write to an XML file.
DataTable dtColumns = conn.GetSchema("Columns");
dtColumns.WriteXml(ProviderName + "_Columns.xml");
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
Console.WriteLine(ex.StackTrace);
}
}
}
}
このメソッドは、コレクション名に指定された文字列および制限値に指定された文字列配列を使用してOracleConnectionのデータ・ソースのスキーマ情報を戻します。
宣言
// ADO.NET 2.0: C# public override DataTable GetSchema (string collectionName, string[] restrictions);
パラメータ
collectionName
取得するメタデータのコレクションの名前
restrictions
取得するメタデータに適用される制限事項の配列
戻り値
DataTableオブジェクト
例外
ArgumentException: 要求されたコレクションが定義されていません。
InvalidOperationException: 次のいずれかの条件が存在します。
接続がクローズされています。
要求されたコレクションが、現行バージョンのOracle Databaseでサポートされていません。
要求されたコレクションでサポートされる以上の制限事項が指定されました。
要求されたコレクションに対して移入文字列が指定されていません。
備考
このメソッドでは、戻されたDataTableのフィルタ処理のために、メタデータ・コレクションの名前および制限事項を指定したString値を使用します。このメソッドは、指定されたメタデータ・コレクションから指定された制限事項に一致する行のみを含むDataTableを戻します。
たとえばColumnsコレクションに3つの制限事項(owner、tablenameおよびcolumnname)がある場合、スキーマに関係なくEMP表のすべての列を取得するには、GetSchemaメソッドは最小限NULL、EMPの値を渡す必要があります。
制限値が渡されない場合、その制限事項に対してデフォルト値が使用されますが、これはNULLを渡すことと同等です。これは、パラメータ値に空の文字列を渡すのとは異なります。この場合、空の文字列("")は指定されたパラメータの値とみなされます。
collectionNameでは大/小文字を区別されませんが、制限事項(文字列値)では区別されます。
例
// C#
using System;
using System.Data;
using System.Data.Common;
using Oracle.DataAccess.Client;
class GetSchemaSample
{
static void Main(string[] args)
{
string constr = "User Id=scott; Password=tiger; Data Source=oracle;";
string ProviderName = "Oracle.DataAccess.Client";
DbProviderFactory factory = DbProviderFactories.GetFactory(ProviderName);
using (DbConnection conn = factory.CreateConnection())
{
try
{
conn.ConnectionString = constr;
conn.Open();
//Get Restrictions
DataTable dtRestrictions =
conn.GetSchema(DbMetaDataCollectionNames.Restrictions);
DataView dv = dtRestrictions.DefaultView;
dv.RowFilter = "CollectionName = 'Columns'";
dv.Sort = "RestrictionNumber";
for (int i = 0; i < dv.Count; i++)
Console.WriteLine("{0} (default) {1}" ,
dtRestrictions.Rows[i]["RestrictionName"],
dtRestrictions.Rows[i]["RestrictionDefault"]);
//Set restriction string array
string[] restrictions = new string[3];
//Get all columns from all tables owned by "SCOTT"
restrictions[0] = "SCOTT";
DataTable dtAllScottCols = conn.GetSchema("Columns", restrictions);
// clear collection
for (int i = 0; i < 3; i++)
restrictions[i] = null;
//Get all columns from all tables named "EMP" owned by any
//owner/schema
restrictions[1] = "EMP";
DataTable dtAllEmpCols = conn.GetSchema("Columns", restrictions);
// clear collection
for (int i = 0; i < 3; i++)
restrictions[i] = null;
//Get columns named "EMPNO" from tables named "EMP",
//owned by any owner/schema
restrictions[1] = "EMP";
restrictions[2] = "EMPNO";
DataTable dtAllScottEmpCols = conn.GetSchema("Columns", restrictions);
// clear collection
for (int i = 0; i < 3; i++)
restrictions[i] = null;
//Get columns named "EMPNO" from all
//tables, owned by any owner/schema
restrictions[2] = "EMPNO";
DataTable dtAllEmpNoCols = conn.GetSchema("Columns", restrictions);
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
Console.WriteLine(ex.Source);
}
}
}
}
GetSessionInfoは、セッションのグローバリゼーションの設定を表すOracleGlobalizationオブジェクトを戻すか、またはリフレッシュします。
オーバーロード・リスト:
このメソッドは、セッションのグローバリゼーションの設定を表すOracleGlobalizationオブジェクトの新規インスタンスを戻します。
GetSessionInfo(OracleGlobalization)
このメソッドは、セッションのグローバリゼーションの設定とともに指定されたOracleGlobalizationオブジェクトをリフレッシュします。
このメソッドは、セッションのグローバリゼーションの設定を表すOracleGlobalizationオブジェクトの新規インスタンスを戻します。
宣言
// C# public OracleGlobalization GetSessionInfo();
戻り値
新規に作成されたOracleGlobalizationオブジェクト
例
// C#
using System;
using Oracle.DataAccess.Client;
class GetSessionInfoSample
{
static void Main()
{
string constr = "User Id=scott;Password=tiger;Data Source=oracle";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Get session info from connection object
OracleGlobalization info = con.GetSessionInfo();
// Update session info
info.DateFormat = "YYYY-MM-DD";
con.SetSessionInfo(info);
// Execute SQL SELECT
OracleCommand cmd = con.CreateCommand();
cmd.CommandText = "select TO_CHAR(hiredate) from emp";
Console.WriteLine("Hire Date ({0}): {1}",
info.DateFormat, cmd.ExecuteScalar());
// Clean up
cmd.Dispose();
con.Dispose();
}
}
このメソッドは、セッションのグローバリゼーションの設定とともに指定されたOracleGlobalizationオブジェクトをリフレッシュします。
宣言
// C#
public void GetSessionInfo(OracleGlobalization oraGlob);
パラメータ
oraGlob
更新されるOracleGlobalizationオブジェクト
このメソッドは、接続をOracle Databaseにオープンします。
宣言
// ADO.NET 2.0: C# public overide void Open();
// ADO.NET 1.x: C#
public void Open();
実装
IDbConnection
例外
ObjectDisposedException: オブジェクトはすでに処理されています。
InvalidOperationException: 接続がすでにオープンしているか、または接続文字列がNULLまたは空です。
備考
接続プーリングが有効な場合、接続がプールから取得されます。それ以外の場合は、新規接続が確立されます。
Open()メソッドが起動されたときに、プールに未処理の接続が含まれていない可能性があります。この場合、新規接続が確立されます。
指定した接続タイムアウト値内で有効な接続がない場合、Max Pool Sizeに達したときにOracleExceptionがスローされます。
このメソッドは、新規パスワードで新規接続をオープンします。
宣言
// C#
public void OpenWithNewPassword(string newPassword);
パラメータ
newPassword
新規パスワードを含む文字列
備考
このメソッドは、新規接続を確立するためにConnectionStringプロパティの設定を使用します。旧パスワードは、Password属性値として接続文字列に指定する必要があります。
このメソッドは、クローズ状態内のOracleConnectionにのみコールされます。
備考(.NETストアド・プロシージャ)
このメソッドは、暗黙的なデータベース接続ではサポートされていません。
このメソッドは、文キャッシングが有効な場合、データベースでオープンしているすべてのカーソルをクローズして文キャッシュをフラッシュします
宣言
// C# public void PurgeStatementCache();
備考
文キャッシュを繰り返しフラッシュするとパフォーマンスが低下し、文キャッシュを有効にすることによるパフォーマンス上の利点を相殺してしまうことがあります。
PurgeStatementCacheを呼び出した後、文キャッシングは有効なままです。
このメソッドを起動すると、OracleConnectionに関連付けられた、キャッシュされているカーソルがパージされます。データベース内にキャッシュされているすべてのカーソルがパージされるわけではありません。
例
// C#
using System;
using System.Data;
using Oracle.DataAccess.Client;
class PurgeStatementCacheSample
{
static void Main()
{
string constr = "User Id=scott;Password=tiger;Data Source=oracle;" +
"Statement Cache Size=20";
OracleConnection con = new OracleConnection(constr);
con.Open();
OracleCommand cmd = new OracleCommand("select * from emp", con);
cmd.CommandType = CommandType.Text;
OracleDataReader reader = cmd.ExecuteReader();
// Purge Statement Cache
con.PurgeStatementCache();
// Close and Dispose OracleConnection object
Console.WriteLine("Statement Cache Flushed");
con.Close();
con.Dispose();
}
}
このメソッドは、セッションのグローバリゼーションの設定を、OracleGlobalizationオブジェクトにより指定されたすべてのプロパティ値で変更します。
宣言
// C#
public void SetSessionInfo(OracleGlobalization oraGlob);
パラメータ
oraGlob
OracleGlobalizationオブジェクト
備考
このメソッドのコールは、セッションにおけるALTER SESSION SQLのコールと同等です。
例
// C#
using System;
using Oracle.DataAccess.Client;
class SetSessionInfoSample
{
static void Main()
{
string constr = "User Id=scott;Password=tiger;Data Source=oracle";
OracleConnection con = new OracleConnection(constr);
con.Open();
// Get session info from connection object
OracleGlobalization info = con.GetSessionInfo();
// Update session info
info.DateFormat = "YYYY-MM-DD";
con.SetSessionInfo(info);
// Execute SQL SELECT
OracleCommand cmd = con.CreateCommand();
cmd.CommandText = "select TO_CHAR(hiredate) from emp";
Console.WriteLine("Hire Date ({0}): {1}",
info.DateFormat, cmd.ExecuteScalar());
// Clean up
cmd.Dispose();
con.Dispose();
}
}
OracleConnectionイベントのリストを、表5-28に示します。
表5-28 OracleConnectionイベント
| イベント名 | 説明 |
|---|---|
|
|
|
|
Oracleフェイルオーバーが発生するときにトリガーされるイベント .NETストアド・プロシージャではサポートされません |
|
|
すべてのメッセージにトリガーされるイベントまたはデータベースにより送信される警告 |
|
|
接続の状態が変更されたときにトリガーされるイベント |
このイベントは、Oracleフェイルオーバーが発生するときにトリガーされるイベントです。
宣言
// C# public event OracleFailoverEventHandler Failover;
イベント・データ
このイベント・ハンドラは、イベントに関する情報を含む次のプロパティを公開するOracleFailoverEventArgsオブジェクトを受信します。
FailoverType
フェイルオーバーのタイプを示します。
FailoverEvent
フェイルオーバーの状態を示します。
備考
Failoverイベントは、Oracleインスタンスへの接続が予期せずに切断されると発生します。クライアントはこのイベントをリスニングするためにOracleFailoverEventHandlerデリゲートを作成する必要があります。
このイベントは、すべてのメッセージにトリガーされるかまたはデータベースにより警告が送信されます。
宣言
// C# public event OracleInfoMessageEventHandler InfoMessage;
イベント・データ
このイベント・ハンドラは、イベントに関する情報を含む次のプロパティを公開するOracleInfoMessageEventArgsオブジェクトを受信します。
Errors
データ・ソースにより生成されたエラーの収集
Message
データ・ソースにより生成されたエラー・テキスト
Source
エラーを生成するオブジェクトの名前
備考
データベースから警告およびメッセージに応答するには、クライアントはこのイベントをリスニングするためにOracleInfoMessageEventHandlerデリゲートを作成する必要があります。
このイベントは、接続の状態が変更されたときにトリガーされます。
宣言
// ADO.NET 2.0: C# public override event StateChangeEventHandler StateChange;
// ADO.NET 1.x: C#
public event StateChangeEventHandler StateChange;
イベント・データ
このイベント・ハンドラは、イベントに関する情報を含む次のプロパティを公開するStateChangeEventArgsオブジェクトを受信します。
CurrentState
接続の新しい状態
OriginalState
接続の元の状態
備考
StateChangeイベントは接続が状態を変更した後に発生し、明示的にOpen、CloseまたはDisposeがコールされます。
|
参照:
|