ヘッダーをスキップ
Oracle Data Provider for .NET開発者ガイド
11g リリース1(11.1)
E05791-01
  目次へ
目次
索引へ
索引

戻る
戻る
 
次へ
次へ
 

OracleConnectionクラス

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コンストラクタ

OracleConnectionコンストラクタのリストを、表5-17に示します。

表5-17 OracleConnectionコンストラクタ

コンストラクタ 説明

OracleConnectionコンストラクタ

OracleConnectionクラスの新規インスタンスをインスタンス化します(オーバーロード)


OracleConnection静的プロパティ

OracleConnection静的プロパティのリストを、表5-19に示します。

表5-18 OracleConnection静的プロパティ

プロパティ 説明

IsAvailable


暗黙的なデータベース接続が使用できるかどうかを示します。


OracleConnection静的メソッド

OracleConnection静的メソッドのリストを、表5-19にリストします。

表5-19 OracleConnection静的メソッド

メソッド 説明

Equals

System.Objectからの継承(オーバーロード)

ClearPool


指定されたOracleConnectionオブジェクトに関連付けられている接続プールを消去します

.NETストアド・プロシージャではサポートされません

ClearAllPools


すべての接続プールからすべての接続を消去します

.NETストアド・プロシージャではサポートされません


OracleConnectionプロパティ

OracleConnectionプロパティのリストを、表5-20に示します。

表5-20 OracleConnectionプロパティ

名前 説明

ClientId


接続のクライアント識別子を指定します

ConnectionString

Oracle Databaseへの接続に使用される接続情報を指定します

ConnectionTimeout

Openメソッドが要求を終了する前にプールされた接続の取得に要する最大時間を示します

Container

System.ComponentModel.Componentからの継承

Database


サポート対象外

DataSource


接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミングを指定します

ServerVersion

OracleConnectionが接続を確立するOracle Databaseのバージョン番号を指定します

Site

System.ComponentModel.Componentからの継承

State

接続の現在の状態を指定します


OracleConnectionパブリック・メソッド

OracleConnectionパブリック・メソッドのリストを、表5-21に示します。

表5-21 OracleConnectionパブリック・メソッド

パブリック・メソッド 説明

BeginTransaction

ローカル・トランザクションを開始します(オーバーロード)

.NETストアド・プロシージャではサポートされません

ChangeDatabase

サポート対象外

Clone


OracleConnectionオブジェクトのコピーを作成します

.NETストアド・プロシージャではサポートされません

Close


データベース接続をクローズします

CreateCommand

OracleConnectionオブジェクトに関連付けられたOracleCommandオブジェクトを作成して戻します

CreateObjRef

System.MarshalByRefObjectからの継承

Dispose

System.ComponentModel.Componentからの継承

EnlistDistributedTransaction


アプリケーションによって、指定された分散トランザクションに明示的に登録できるようにします

.NETストアド・プロシージャではサポートされません

EnlistTransaction


アプリケーションによって、指定された分散トランザクションに登録できるようにします

ADO.NET 2.0準拠のODP.NETでのみサポート

.NETストアド・プロシージャではサポートされません

Equals

System.Objectからの継承(オーバーロード)

GetHashCode

System.Objectからの継承

GetLifetimeService

System.MarshalByRefObjectからの継承

GetSchema


OracleConnectionのデータ・ソースのスキーマ情報を戻します

ADO.NET 2.0準拠のODP.NETでのみサポート

GetSessionInfo

セッションのグローバリゼーションの設定を表すOracleGlobalizationオブジェクトのプロパティ値を戻すか、またはリフレッシュします(オーバーロード)

GetType

System.Objectからの継承

InitializeLifetimeService

System.MarshalByRefObjectからの継承

Open

ConnectionStringにより指定されたプロパティの設定でデータベース接続をオープンします

OpenWithNewPassword

新規パスワードで新規接続をオープンします

.NETストアド・プロシージャではサポートされません

PurgeStatementCache


文キャッシングが有効な場合、データベースでオープンしているすべてのカーソルをクローズし、文キャッシュをフラッシュします

SetSessionInfo

セッションのグローバリゼーションの設定をOracleGlobalizationオブジェクトにより指定されたプロパティ値で変更します

ToString

System.Objectからの継承


OracleConnectionイベント

OracleConnectionイベントのリストを、表5-22に示します。

表5-22 OracleConnectionイベント

イベント名 説明

Disposed

System.ComponentModel.Componentからの継承

Failover

Oracleフェイルオーバーが発生するときにトリガーされるイベント

.NETストアド・プロシージャではサポートされません

InfoMessage

すべてのメッセージにトリガーされるイベントまたはデータベースにより送信される警告

StateChange

接続の状態が変更されたときにトリガーされるイベント



OracleConnectionコンストラクタ

OracleConnectionコンストラクタはOracleConnectionクラスの新規インスタンスをインスタンス化します。

オーバーロード・リスト:

OracleConnection()

このコンストラクタは、デフォルト・プロパティ値を使用してOracleConnectionクラスの新規インスタンスをインスタンス化します。

宣言

// C#
public OracleConnection();

備考

OracleConnectionのプロパティは次のデフォルト値に設定されます。

OracleConnection(String)

このコンストラクタは、指定された接続文字列とともにOracleConnectionクラスの新規インスタンスをインスタンス化します。

宣言

// C#
public OracleConnection(String connectionString);

パラメータ

備考

ConnectionStringプロパティは、指定されたconnectionStringに設定されます。ConnectionStringプロパティは解析され、無効な接続文字列属性または属性値が含まれる場合は、例外がスローされます。

OracleConnectionオブジェクトのプロパティは、接続文字列により設定されない場合は、次の値をデフォルトとします。


OracleConnection静的プロパティ

OracleConnection静的プロパティのリストを、表5-23にリストします。

表5-23 OracleConnection静的プロパティ

プロパティ 説明

IsAvailable


暗黙的なデータベース接続が使用できるかどうかを示します。


IsAvailable

このプロパティは、暗黙的なデータベース接続が使用できるかどうかを示します。

宣言

// 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静的メソッド

OracleConnection静的メソッドのリストを、表5-24にリストします。

表5-24 OracleConnection静的メソッド

メソッド 説明

Equals

System.Objectからの継承(オーバーロード)

ClearPool


指定されたOracleConnectionオブジェクトに関連付けられている接続プールを消去します

.NETストアド・プロシージャではサポートされません

ClearAllPools


すべての接続プールからすべての接続を消去します

.NETストアド・プロシージャではサポートされません


ClearPool

このメソッドは、指定された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!");
  }
}

ClearAllPools

このメソッドは、すべての接続プールからすべての接続を消去します。

宣言

// 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プロパティ

OracleConnectionプロパティのリストを、表5-25に示します。

表5-25 OracleConnectionプロパティ

名前 説明

ClientId


接続のクライアント識別子を指定します

ConnectionString

Oracle Databaseへの接続に使用される接続情報を指定します

ConnectionTimeout

Openメソッドが要求を終了する前にプールされた接続の取得に要する最大時間を示します

Container

System.ComponentModel.Componentからの継承

Database


サポート対象外

DataSource


接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミングを指定します

ServerVersion

OracleConnectionが接続を確立するOracle Databaseのバージョン番号を指定します

Site

System.ComponentModel.Componentからの継承

State

接続の現在の状態を指定します


ClientId

このプロパティでは、接続のクライアント識別子を指定します。

宣言

// C#
public string ClientId {set;}

プロパティ値

クライアント識別子として使用される文字列

備考

デフォルト値はnullです。

ClientIdnullに設定すると、接続のクライアント識別子がリセットされます。ClientIdを空の文字列に設定すると、接続のクライアント識別子が空の文字列に設定されます。OracleConnectionオブジェクトでCloseメソッドがコールされると、ClientIdnullに設定されます。

ClientIdプロパティを使用すると、アプリケーションでODP.NETを使用する各データベース・セッションに対してアプリケーション・コンテキスト内にクライアント識別子を設定できます。これによりODP.NET開発者は、Oracle Virtual Private Database(VPD)をより簡単に構成できるようになります。

ConnectionString

このプロパティは、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 IdPasswordProxy User IdProxy Password、およびData Source(提供されている場合)の属性値は、Openメソッドがコールされるまで検証されません。

接続はクローズして、ConnectionStringプロパティに設定する必要があります。ConnectionStringプロパティがリセットされる場合、事前に設定された値は、新しい値が適用される前にそれぞれのデフォルト値に再初期化されます。

ODP.NET 11.1以降では、パスワードおよびプロキシ・パスワード接続文字列属性値の大/小文字が区別されます。 そのため、接続文字列に指定された大/小文字のまま、認証用データベースに渡されます。 そのため、パスワードの大/小文字を区別するようにデータベースが構成されている場合は、正しい大/小文字を使用してパスワードを渡す必要があります。

接続文字列属性が2回以上設定されている場合、最新の設定が実行され、例外はスローされません。

ブール接続文字列属性は、truefalseyesまたはnoのいずれかに設定できます。

備考(.NETストアド・プロシージャ)

暗黙的なデータベース接続を表すOracleConnectionオブジェクトを.NETストアド・プロシージャで取得するには、OracleConnectionオブジェクトのConnectionStringプロパティを"context connection=true"に設定し、Openメソッドを起動します。"context connection"がtrueに設定されている場合、その他の接続文字列属性を一緒に使用することはできません。

サポートされている接続文字列属性

表5-26に、サポートされている接続文字列の属性リストを示します。

表5-26 サポートされている接続文字列の属性

接続文字列属性 説明 デフォルト値

Connection Lifetime

接続の最大存続期間(秒)。

この属性は、接続の存続期間を秒単位で指定します。Connectionがプールに戻される前に、接続の存続期間がチェックされます。接続の存続期間がこのプロパティ値を超える場合、接続はクローズされ、処理されます。このプロパティ値が0の場合、接続存続期間は1度もチェックされません。存続期間を超えた接続はクローズまたは処理されません。クローズまたは処理するには、プール内の接続の数をMin Pool Sizeよりも小さくします。

0

Connection Timeout

プールから使用可能な接続を待機する最大時間(秒)。

この属性は、Open()メソッドが要求を終了する前にプールされた接続の取得に要する最大時間(秒)を指定します。この値は、接続プールからの使用可能な接続がない場合、およびMax Pool Sizeに達した場合にのみ有効になります。使用可能な接続が指定された時間内に使用できない場合、例外がスローされます。Connection Timeoutは、新規接続のオープン時に必要とする時間を制限しません。

この属性値はプールされた接続要求に対して有効となりますが、新規接続要求に対しては有効にはなりません。

(.NETストアド・プロシージャにおける暗黙的なデータベース接続のデフォルト値は0です。)

15

Context Connection

trueに設定した場合、暗黙的なデータベース接続が戻されます。

暗黙的なデータベース接続は、.NETストアド・プロシージャ内からのみ取得できます。context connectiontrueに設定されている場合、その他の接続文字列属性を一緒に使用することはできません。

.NETストアド・プロシージャでのみサポートされています。

false

Data Source

接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミング。

空の文字列

DBA Privilege

管理者権限SYSDBAまたはSYSOPER

この接続文字列属性は、属性値としてSYSDBAまたはSYSOPERのみを受け入れます。大文字または小文字を区別しません。

空の文字列

Decr Pool Size

未使用の確立済接続量が過剰となり、クローズされる接続数。

1

 

この接続文字列の属性は、プール・レギュレータが定期的なチェックを行う場合、クローズされる未使用の最大接続数を制御します。このレギュレータ・スレッドは3分ごとに生成され、プールされた接続が使用されていない場合、その接続のDecr Pool Size量に達するまでクローズします。プール・レギュレータは、プールされた接続をクローズすることによりMin Pool Size未満の接続の合計数を取りません。

 


Enlist

COM+トランザクションまたはSystem.Transactionsのコンテキストで、接続の登録動作および機能を制御します。

この属性がtrueに設定されている場合、接続は自動的にスレッドのトランザクション・コンテキストに登録されます。この属性がfalseの場合、登録はおこなわれません。この属性がdynamicに設定されている場合、アプリケーションは動的に分散トランザクションに登録できます。この属性は、truefalseyesnoまたはdynamicのいずれかに設定できます。

true

HA Events

RACサービス、サービス・メンバーまたはノードが停止した場合、ODP.NET接続プールが予防的にプールから接続を削除できるようにします。

この機能は、"pooling=true"の場合にかぎり、RACデータベースに対してのみ使用できます。

この属性は、truefalseyesまたはnoのいずれかに設定できます。

false

Load Balancing

ODP.NET接続プールを使用して、ロード・バランス・アドバイザおよびサービス目標に基づき、RACインスタンス間の作業要求のバランスを調整できます。

この機能は、"pooling=true"の場合にかぎり、RACデータベースに対してのみ使用できます。

この属性は、truefalseyesまたはnoのいずれかに設定できます。

false

Incr Pool Size

プール内のすべての接続が使用された場合に作成される新しい接続の数。

この接続文字列属性は、プールされた接続が要求されたときに確立される新規接続の数を決定しますが、未使用の接続は使用不可であり、Max Pool Sizeに達しません。新規接続がプールに作成された場合、レギュレータ・スレッドはサイクルをスキップし、すべての接続は6分間クローズされません。ただし、接続の存続期間を超過している場合は、この間に一部の接続がまだクローズ可能なことに注意してください。

5

Max Pool Size

プール内の接続の最大数。

この属性は、OracleConnectionにより使用された特定のプール内に許可された接続の最大数を指定します。接続文字列でこの属性を変更するだけでは、現在すでに存在するプールのMax Pool Size制限は変更されません。このようにして、異なるMax Pool Size制限で新規プールが容易に作成できます。この属性は、Min Pool Sizeより大きな値に設定する必要があります。この値は、Poolingが稼動していない場合、無視されます。

100

Metadata Pooling

メタデータ情報をキャッシュします。

この属性は、実行された問合せのメタデータ情報を、性能向上のためにキャッシュするかどうかを示します。

True

Min Pool Size

プール内の接続の最小数。

この属性は、プールのすべての存続期間中、プールにより保持される接続の最少数を指定します。接続文字列でこの属性を変更するだけでは、現在すでに存在するプールのMin Pool Size制限は変更されません。このようにして、異なるMin Pool Size制限で新規プールが容易に作成できます。この値は、Poolingが稼動していない場合、無視されます。

1

Password

User Idにより指定されたユーザーのパスワード。

この属性はOracleユーザーのパスワードを指定します。 Passwordでは、大/小文字が区別されます。

空の文字列

Persist Security Info

接続文字列でのパスワード検索。

この属性がfalseに設定されている場合、Passwordの値の設定はOpen()メソッドにより接続が正常にオープンされた後にアプリケーションがConnectionStringを要求する場合には戻されません。この属性は、truefalseyesまたはnoのいずれかに設定できます。

false

Pooling

接続プーリング。

この属性は、接続プーリングを使用する必要があるかどうかを指定します。プールは、属性値が一致するアルゴリズムを使用して作成されます。つまり、接続文字列内で単にスペースの数が異なる接続文字列は、同じプールを使用することを意味します。一方の接続文字列では属性をデフォルト値に設定し、もう一方の接続文字列でその属性を設定しないという点を除いて、2つの接続文字列が一致する場合、両方の要求とも同じプールから接続を取得します。この属性は、truefalseyesまたはnoのいずれかに設定できます。

true

Proxy User Id

プロキシ・ユーザーのユーザー名。

この接続文字列属性は、User Id属性により指定されたクライアント・ユーザーの代わりに接続を確立する中間層のユーザーまたはプロキシ・ユーザーを指定します。ODP.NETは、Proxy User IdまたはProxy Password属性のいずれかが空ではない文字列に設定されている場合、プロキシ接続の確立を試みます。

空の文字列

 

プロキシ・ユーザーがオペレーティング・システム認証を使用してOracle Databaseに接続するには、Proxy User Id"/"に設定する必要があります。Proxy Passwordは、この場合無視されます。 User Idは、プロキシ接続を確立している場合、"/"に設定できません。 この属性値の大/小文字はそのまま維持されます。

 


Proxy Password

プロキシ・ユーザーのパスワード。

この接続文字列属性は、中間層のユーザーまたはプロキシ・ユーザーのパスワードを指定します。このユーザーは、User Id属性により指定されたクライアント・ユーザーのかわりに接続を確立します。ODP.NETは、Proxy User IdまたはProxy Password属性のいずれかが空ではない文字列に設定されている場合、プロキシ接続の確立を試みます。

二重引用符によりこの属性値が囲まれている場合、この場合の属性値は保持されます。

空の文字列

Statement Cache Purge

接続がプールに戻るときの文キャッシュの消去。

文キャッシングが有効な場合、この属性をtrueに設定すると、接続がプールに戻される際に文キャッシュがパージされます。

false

Statement Cache Size

文キャッシュを有効にして、キャッシュ・サイズ、つまりキャッシュ可能な文の最大数のサイズを設定します。

文キャッシングはゼロより大きい値で可能で、キャッシュ・サイズはその値に設定されます。この値は、init.oraデータベース構成ファイルにあるOPEN_CURSORSパラメータ・セットの値以下にする必要があります。

10

User Id

Oracleユーザー名。

この属性は、Oracleユーザー名を指定します。二重引用符によりこの属性値が囲まれている場合、この場合の属性値は保持されます。 ユーザーがオペレーティング・システム認証を使用してOracle Databaseに接続するには、User Id"/"に設定する必要があります。すべてのPassword属性の設定は、この場合無視されます。

空の文字列

Validate Connection

プールを使用している接続の検証。

検証により、各接続に対してデータベースにラウンドトリップが発生します。このため、必要な場合のみ使用してください。

false


ConnectionTimeout

このプロパティは、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に設定されます。

Database

このプロパティは、サポートされていません。

宣言

// ADO.NET 2.0: C#
public override string Database {get;}

// ADO.NET 1.x: C#
public string Database {get;}

プロパティ値

文字列

実装

IDbConnection.Database

備考

このプロパティは、サポートされていません。これは常に空の文字列を戻します。

DataSource

このプロパティは、接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミングを指定します

宣言

// ADO.NET 2.0: C#
public override string DataSource {get;}

// ADO.NET 1.x: C#
public string DataSource {get;}

プロパティ値

接続するデータベースを識別するOracle Netサービス名、接続記述子または簡易接続ネーミング。

備考(.NETストアド・プロシージャ)

暗黙的なデータベース接続の場合、このプロパティの値は常に空の文字列です。

ServerVersion

このプロパティは、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: 接続がクローズされています。

備考

デフォルトは空の文字列です。

State

このプロパティは、接続の現在の状態を指定します。

宣言

// 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パブリック・メソッド

OracleConnectionパブリック・メソッドのリストを、表5-27に示します。

表5-27 OracleConnectionパブリック・メソッド

パブリック・メソッド 説明

BeginTransaction

ローカル・トランザクションを開始します(オーバーロード)

.NETストアド・プロシージャではサポートされません

ChangeDatabase

サポート対象外

Clone


OracleConnectionオブジェクトのコピーを作成します

.NETストアド・プロシージャではサポートされません

Close


データベース接続をクローズします

CreateCommand

OracleConnectionオブジェクトに関連付けられたOracleCommandオブジェクトを作成して戻します

CreateObjRef

System.MarshalByRefObjectからの継承

Dispose

System.ComponentModel.Componentからの継承

EnlistDistributedTransaction


アプリケーションによって、指定された分散トランザクションに明示的に登録できるようにします

.NETストアド・プロシージャではサポートされません

EnlistTransaction


アプリケーションによって、指定された分散トランザクションに登録できるようにします

ADO.NET 2.0準拠のODP.NETでのみサポート

.NETストアド・プロシージャではサポートされません

Equals

System.Objectからの継承(オーバーロード)

GetHashCode

System.Objectからの継承

GetLifetimeService

System.MarshalByRefObjectからの継承

GetSchema


OracleConnectionのデータ・ソースのスキーマ情報を戻します

ADO.NET 2.0準拠のODP.NETでのみサポート

GetSessionInfo

セッションのグローバリゼーションの設定を表すOracleGlobalizationオブジェクトのプロパティ値を戻すか、またはリフレッシュします(オーバーロード)

GetType

System.Objectからの継承

InitializeLifetimeService

System.MarshalByRefObjectからの継承

Open

ConnectionStringにより指定されたプロパティの設定でデータベース接続をオープンします

OpenWithNewPassword

新規パスワードで新規接続をオープンします

.NETストアド・プロシージャではサポートされません

PurgeStatementCache


文キャッシングが有効な場合、データベースでオープンしているすべてのカーソルをクローズし、文キャッシュをフラッシュします

SetSessionInfo

セッションのグローバリゼーションの設定をOracleGlobalizationオブジェクトにより指定されたプロパティ値で変更します

ToString

System.Objectからの継承


BeginTransaction

BeginTransactionメソッドは、ローカル・トランザクションを開始します。

オーバーロード・リスト

BeginTransaction()

このメソッドは、ローカル・トランザクションを開始します。

宣言

// C#
public OracleTransaction BeginTransaction();

戻り値

OracleTransactionオブジェクトは、新規トランザクションを表します。

実装

IDbConnection

例外

InvalidOperationException: トランザクションはすでに開始されています。

備考

トランザクションは、分離レベルで作成され、IsolationLevel.ReadCommittedのデフォルト値に設定されます。トランザクションに関連するすべての後続の操作は、戻されたOracleTransactionオブジェクトで実行する必要があります。

備考(.NETストアド・プロシージャ)

このメソッドを使用すると、未サポートの例外が発生します。

BeginTransaction(IsolationLevel)

このメソッドは、ローカル・トランザクションを指定された分離レベルで開始します。

宣言

// C#
public OracleTransaction BeginTransaction(IsolationLevel isolationLevel);

パラメータ

戻り値

OracleTransactionオブジェクトは、新規トランザクションを表します。

実装

IDbConnection

例外

InvalidOperationException: トランザクションはすでに開始されています。

ArgumentException: 指定したisolationLevel値が無効です。

備考

次の2つの分離レベルがサポートされています。

他の分離レベルを要求すると、例外が発生します。

備考(.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();
  }
}

ChangeDatabase

このメソッドは、サポートされていません。

宣言

// ADO.NET 2.0: C#
public override void ChangeDatabase(string databaseName);

// ADO.NET 1.x: C#
public void ChangeDatabase(string databaseName);

パラメータ

実装

IDbConnection.ChangeDatabase

例外

NotSupportedException: メソッドはサポートされていません。

備考

このメソッドはサポートされておらず、起動されるとNotSupportedExceptionをスローします。

Clone

このメソッドは、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();
  }
}

Close

このメソッドは、データベースへの接続をクローズします。

宣言

// ADO.NET 2.0: C#
public override void Close();

// ADO.NET 1.x: C#
public void Close();

実装

IDbConnection

備考

次を実行します。

接続は、Open()を使用して再オープンできます。

CreateCommand

このメソッドは、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();
  }
}

EnlistDistributedTransaction

このメソッドにより、アプリケーションは接続がオープンされた後に特定の分散トランザクションに明示的に登録できます。

宣言

// C#
public void EnlistDistributedTransaction(ITransaction transaction);

パラメータ

例外

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();
    }
  }
}


参照:


EnlistTransaction

このメソッドは、指定されたトランザクションに接続を登録します。

ADO.NET 2.0準拠のODP.NETでのみサポート

宣言

// C#
public override void EnlistTransaction(Transaction transaction)

パラメータ

例外

InvalidOperationException - 接続がローカル・トランザクションの一部であるか、または接続がクローズされています。

備考

このメソッドを起動すると、指定されたトランザクション・パラメータにより指定された分散トランザクションに接続が即時登録されます。

OracleConnectionが、前に起動したEnlistTransactionメソッドを完了していない分散トランザクションと関連付けられたままの場合、このメソッドの呼出しにより例外がスローされます。

一般に、分散トランザクションでの登録が正常に行われるためには、Openメソッドを起動する前に"enlist"接続文字列属性を"true"または"dynamic"のいずれかに設定する必要があります。"enlist"接続文字列属性を"true"に設定すると、接続がトランザクション・コンテキスト内にあれば、Openメソッドが呼び出されたときに暗黙的にその接続が登録されます。"dynamic"に設定すると、EnlistTransactionまたはEnlistDistributedTransactionメソッドが呼び出されたときに接続を動的に分散トランザクションに登録できます。"enlist"属性を"false"に設定するのは、接続が分散トランザクションに登録されることがない場合のみです。

GetSchema

GetSchemaメソッドは、OracleConnectionのデータ・ソースのスキーマ情報を戻します。

ADO.NET 2.0準拠のODP.NETでのみサポート

オーバーロード・リスト

GetSchema()

このメソッドは、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);
      }
    }
  }
}

GetSchema (string collectionName)

このメソッドは、コレクション名に指定された文字列を使用して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);
      }
    }
  }
}

GetSchema (string collectionName, string[] restrictions)

このメソッドは、コレクション名に指定された文字列および制限値に指定された文字列配列を使用してOracleConnectionのデータ・ソースのスキーマ情報を戻します。

宣言

// ADO.NET 2.0: C#
public override DataTable GetSchema (string collectionName,
    string[] restrictions);

パラメータ

戻り値

DataTableオブジェクト

例外

備考

このメソッドでは、戻されたDataTableのフィルタ処理のために、メタデータ・コレクションの名前および制限事項を指定したString値を使用します。このメソッドは、指定されたメタデータ・コレクションから指定された制限事項に一致する行のみを含むDataTableを戻します。

たとえばColumnsコレクションに3つの制限事項(ownertablenameおよび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

GetSessionInfoは、セッションのグローバリゼーションの設定を表すOracleGlobalizationオブジェクトを戻すか、またはリフレッシュします。

オーバーロード・リスト:

GetSessionInfo()

このメソッドは、セッションのグローバリゼーションの設定を表す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();
  }
}

GetSessionInfo(OracleGlobalization)

このメソッドは、セッションのグローバリゼーションの設定とともに指定されたOracleGlobalizationオブジェクトをリフレッシュします。

宣言

// C#
public void GetSessionInfo(OracleGlobalization oraGlob);

パラメータ

Open

このメソッドは、接続を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がスローされます。

OpenWithNewPassword

このメソッドは、新規パスワードで新規接続をオープンします。

宣言

// C#
public void OpenWithNewPassword(string newPassword);

パラメータ

備考

このメソッドは、新規接続を確立するためにConnectionStringプロパティの設定を使用します。旧パスワードは、Password属性値として接続文字列に指定する必要があります。

このメソッドは、クローズ状態内のOracleConnectionにのみコールされます。

備考(.NETストアド・プロシージャ)

このメソッドは、暗黙的なデータベース接続ではサポートされていません。

PurgeStatementCache

このメソッドは、文キャッシングが有効な場合、データベースでオープンしているすべてのカーソルをクローズして文キャッシュをフラッシュします

宣言

// 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();
  }
}

SetSessionInfo

このメソッドは、セッションのグローバリゼーションの設定を、OracleGlobalizationオブジェクトにより指定されたすべてのプロパティ値で変更します。

宣言

// C#
public void SetSessionInfo(OracleGlobalization 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イベント

OracleConnectionイベントのリストを、表5-28に示します。

表5-28 OracleConnectionイベント

イベント名 説明

Disposed

System.ComponentModel.Componentからの継承

Failover

Oracleフェイルオーバーが発生するときにトリガーされるイベント

.NETストアド・プロシージャではサポートされません

InfoMessage

すべてのメッセージにトリガーされるイベントまたはデータベースにより送信される警告

StateChange

接続の状態が変更されたときにトリガーされるイベント


Failover

このイベントは、Oracleフェイルオーバーが発生するときにトリガーされるイベントです。

宣言

// C#
public event OracleFailoverEventHandler Failover;

イベント・データ

このイベント・ハンドラは、イベントに関する情報を含む次のプロパティを公開するOracleFailoverEventArgsオブジェクトを受信します。

備考

Failoverイベントは、Oracleインスタンスへの接続が予期せずに切断されると発生します。クライアントはこのイベントをリスニングするためにOracleFailoverEventHandlerデリゲートを作成する必要があります。

InfoMessage

このイベントは、すべてのメッセージにトリガーされるかまたはデータベースにより警告が送信されます。

宣言

// C#
public event OracleInfoMessageEventHandler InfoMessage;

イベント・データ

このイベント・ハンドラは、イベントに関する情報を含む次のプロパティを公開するOracleInfoMessageEventArgsオブジェクトを受信します。

備考

データベースから警告およびメッセージに応答するには、クライアントはこのイベントをリスニングするためにOracleInfoMessageEventHandlerデリゲートを作成する必要があります。

StateChange

このイベントは、接続の状態が変更されたときにトリガーされます。

宣言

// ADO.NET 2.0: C#
public override event StateChangeEventHandler StateChange;

// ADO.NET 1.x: C#
public event StateChangeEventHandler StateChange;

イベント・データ

このイベント・ハンドラは、イベントに関する情報を含む次のプロパティを公開するStateChangeEventArgsオブジェクトを受信します。

備考

StateChangeイベントは接続が状態を変更した後に発生し、明示的にOpenCloseまたはDisposeがコールされます。


参照: