[FIX、OracleDataReader.GetChars メソッドが返す、不正なデータ、.NET Framework 2. 0

文書番号: 922674 - 対象製品
すべて展開する | すべて折りたたむ

目次

現象

Microsoft .NET Framework 2. 0 で、 OracleDataReader.GetChars メソッドが不適切なデータを返す OracleDataReader オブジェクトからデータを読み込むことが 2 回目。 OracleDataReader.Read メソッドを呼び出すこと、2 番目の時刻よりも後、 OracleDataReader.GetChars メソッドは最初の行からデータを返す可能性があります。

解決方法

修正プログラムについて

サポートされている修正プログラムを Microsoft から入手可能なようになりました。 ただし、これはするためのもの、この資料に記載されている問題のみを修正です。 この特定の問題が発生しているシステムにのみ適用します。 この修正プログラム テストを受ける可能性があります。 そのため場合この問題で深刻な影響を受けていないお勧めしますこの修正プログラムを含む次の .NET Framework 2. 0 Service Pack まで待つことです。

この問題を直ちに解決するには、顧客サポート マイクロソフトに連絡の修正プログラムを入手します。 カスタマー サポート サービスの電話番号およびサポートのコストに関する情報の完全な一覧、については、次の Web マイクロソフトを参照してください。
http://support.microsoft.com/contactus/?ws=support
メモ 特殊な場合は、Microsoft Support 担当者により、特定の更新は問題が解決される場合料金がサポート通常発生する可能性があります取り消されます。 通常のサポート料金が追加の質問および問題の特定のアップデートの対象とならない問題について適用されます。

前提条件

必要条件はありません。

再起動の要件

この修正プログラムの適用後、コンピュータを再起動する必要があります。

修正プログラム置き換えに関する情報

修正この修正プログラムはプログラム置き換えられることもほかありません。

ファイル情報

英語版のこの修正プログラムにファイルの属性 (またはそれ以降のファイル属性) 次の表は、されている可能性もします。 日付およびこれらのファイルの時間で世界協定時刻 (UTC) と記載します。 各ファイルの日付および時刻は、世界協定時刻 (UTC) で示されています。 UTC と現地時刻の差を検索するには、コントロール パネルの [日付と時刻 タイム ゾーン タブを使用します。
元に戻す全体を表示する
ファイル名ファイルのバージョンファイルのサイズ日付時間
Mscordacwks.dll2.0.50727.178801,2802006 年 7 月 8 日11: 28
Mscorlib.dll2.0.50727.1784,317,1842006 年 7 月 8 日11: 28
Mscorwks.dll2.0.50727.1785,624,3202006 年 7 月 8 日11: 27
Normalization.dll2.0.50727.17815,3602006 年 7 月 8 日11: 28
Normidna.nlp適用しません。59,3422006 年 7 月 8 日11: 28
Normnfc.nlp適用しません。45,7942006 年 7 月 8 日11: 28
Normnfd.nlp適用しません。39,2842006 年 7 月 8 日11: 28
Normnfkc.nlp適用しません。66,3842006 年 7 月 8 日11: 28
Normnfkd.nlp適用しません。60,2942006 年 7 月 8 日11: 28
Sos.dll2.0.50727.178377,3442006 年 7 月 8 日11: 28
System.data.dll2.0.50727.1782,893,8242006 年 7 月 8 日11: 28
System.data.oracleclient.dll2.0.50727.178482,3042006 年 7 月 8 日11: 28

状況

マイクロソフトとして認識していますこの問題を記載されているいるマイクロソフト製品の問題。

詳細

関連情報を参照するには、以下の「サポート技術情報」 (Microsoft Knowledge Base) をクリックしてください:
824684マイクロソフトのソフトウェアの更新で使用される一般的な用語の説明
OracleDataReader.GetChars メソッドの詳細については、ご覧次マイクロソフト開発者向けネットワーク (MSDN) 下さい。
http://msdn2.microsoft.com/en-us/library/system.data.oracleclient.oracledatareader.getchars(VS.80).aspx

この問題を再現する手順

  1. Microsoft Visual Studio 2005 を開始します。
  2. ファイル ] メニューの [には [ 新規作成 ] をクリックして、[ プロジェクト ] をクリックします。
  3. クリックして Visual C# コンソール アプリケーション ] をクリックして、 ConsoleApplication1 [] ボックスと入力して [OK] をクリックします。
  4. Program.cs ファイル内には既存のコードを次のコードを使用して置き換えます。
    using System;
    using System.Text;
    using System.Data;
    using System.Data.OracleClient;
    
    namespace ConsoleApplication1
    {
        class Program
        {
            private static void Main()
            {
                OracleConnection cn = new OracleConnection("Data Source=<DataSourceName>;uid=<UserName>;pwd=<Password>;");
                cn.Open();
    
                DropTable(cn);
                CreateTable(cn);
    
                OracleCommand command = cn.CreateCommand();
                command.CommandText = "SELECT DATA FROM TEST_GETCHARS ORDER BY DATA DESC";
                OracleDataReader reader = command.ExecuteReader();
                while (reader.Read())
                {
                    string getStringText = reader.GetString(0);
                    char[] chs = new char[40];
                    long count = reader.GetChars(0, 0, chs, 0, 40);
                    String s = new String(chs);
                    Console.WriteLine("String from GetString: {2}, String from GetChars: {0}, Character count: {1}", s, count.ToString(), getStringText);
                }
    
                cn.Close();
                cn = null;
            }
    
            private static void CreateTable(IDbConnection connection)
            {
                IDbCommand command = connection.CreateCommand();
                command.CommandText = "CREATE TABLE TEST_GETCHARS (DATA varchar(40))";
                command.ExecuteNonQuery();
    
                command.CommandText = "INSERT INTO TEST_GETCHARS (DATA) VALUES('yes')";
                command.ExecuteNonQuery();
    
                command.CommandText = "INSERT INTO TEST_GETCHARS (DATA) VALUES('no')";
                for (int i = 0; i < 2000; i++)
                command.ExecuteNonQuery();
    
            }
    
            private static void DropTable(IDbConnection connection)
            {
                try
                {
                    IDbCommand command = connection.CreateCommand();
                    command.CommandText = "DROP TABLE TEST_GETCHARS";
                    command.ExecuteNonQuery();
                }
                catch (Exception)
                {
                }
            }
        }
    }
  5. ソリューション エクスプローラー [参照設定 ] を右クリックし、[ 参照の追加 ] をクリックします。
  6. [ .NET ] タブをクリックして [ System.Data.OracleClient 、] をクリックして [ OK] をクリックします。
  7. [ デバッグ ] の [ デバッグ開始 ] をクリックします。

プロパティ

文書番号: 922674 - 最終更新日: 2007年12月3日 - リビジョン: 1.1
この資料は以下の製品について記述したものです。
  • Microsoft .NET Framework 2.0
キーワード:?
kbbug kbfix kbqfe kbpubtypekc kbhotfixserver kbmt KB922674 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:922674
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック