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

戻る
戻る
 
次へ
次へ
 

OracleConnectionクラス

OracleConnectionオブジェクトは、Oracleデータベースへの接続を表します。

クラスの継承

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.0以降


OracleConnectionメンバー

OracleConnectionメンバーは、次の表にリストされています。

OracleConnectionコンストラクタ

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

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

コンストラクタ 説明

OracleConnectionコンストラクタ

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


OracleConnection静的プロパティ

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

表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データベースへの接続に使用される接続情報を指定します

ConnectionTimeout

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

Container

System.ComponentModel.Componentからの継承

Database


サポート対象外

DataSource


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

ServerVersion

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

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からの継承(オーバーロード)

FlushCache


この接続を使用し、REFオブジェクトを通して検索したすべての更新と削除をフラッシュします

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

備考

これは、アプリケーション用に作成されたすべての接続プールに対して、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データベースへの接続に使用される接続情報を指定します

ConnectionTimeout

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

Container

System.ComponentModel.Componentからの継承

Database


サポート対象外

DataSource


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

ServerVersion

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

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データベースへの接続に使用される接続情報を指定します。

宣言

// 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

ODP.NET接続プールを使用して、Oracle RACサービス、サービス・メンバーまたはノードの停止時に、プールから接続を事前に削除できます。

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

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

false

Load Balancing

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

この機能は、"pooling=true"の場合にかぎり、Oracle 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ユーザーのパスワードを指定します。Oracle Database 11gリリース1(11.1)以降では、デフォルトではPasswordは大/小文字を区別します。

空の文字列

Persist Security Info

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

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

false

Pooling

接続プーリング。

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

true

Promotable Transaction

Promotableが分散トランザクションかどうか。

"promotable"が指定されている場合、同じTransactionScopeでオープンされると最初と後続の接続は、同じ分散トランザクション内で登録されます。"local"が指定されている場合は、TransactionScopeでオープンされる最初の接続はローカル・トランザクションを使用します。

promotable

Proxy User Id

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

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

空の文字列

 

プロキシ・ユーザーがオペレーティング・システム認証を使用してOracleデータベースに接続するには、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データベースに接続するには、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データベースのバージョン番号を指定します。

宣言

// ADO.NET 2.0: C#
public override string ServerVersion {get;}
// ADO.NET 1.x: C#
public string ServerVersion {get;}

プロパティ値

Oracleデータベースのバージョン

例外

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からの継承(オーバーロード)

FlushCache


この接続を使用し、REFオブジェクトを通して検索したすべての更新と削除をフラッシュします

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値が無効です。

備考

分離レベルIsolationLevel.ReadCommittedがサポートされています。

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

備考(.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に対してコミットを起動すると例外が発生します。

ITransactionメソッドに対してロールバックを起動し、同一分散トランザクションに対して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"に設定してください。

FlushCache

このメソッドは、接続を使用して取得されたREFオブジェクトから作成されたすべての更新および削除をフラッシュします。

宣言

// c#
public void FlushCache();

例外

InvalidOperationException: 指定された接続がオープンされていません。

備考

オブジェクトをフラッシュする前に、アプリケーションはOracleConnectionオブジェクト上でBeginTransactionメソッドを実行して明示的にトランザクションを開始する必要があります。これは、フラッシュされるオブジェクトがアプリケーションによりロックされていない場合は、オブジェクトに対して暗黙的に排他的ロックが取得されるためです。ロックが解除されるのは、トランザクションがコミットまたはロールバックする場合にかぎります。

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)メソッドを使用した場合、文字列値"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データベースではサポートされていません。

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内の行をフィルタする制限を指定する文字列値の配列を取得します。これは、指定された制限と一致する指定されたメタデータ・コレクションからの行のみが含まれる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データベースにオープンします。

宣言

// 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がコールされます。


関連項目: