FIX:: OracleDataReader.GetChars 方法可能返回不正确的数据在.net Framework 2.0

文章翻译 文章翻译
文章编号: 922674 - 查看本文应用于的产品
展开全部 | 关闭全部

本文内容

症状

在 Microsoft.net Framework 2.0 中,OracleDataReader.GetChars 方法可能会返回不正确的数据从 OracleDataReader 对象中读取数据的第二次。 第二次调用 OracleDataReader.Read 方法后 OracleDataReader.GetChars 方法可能会返回从第一行的数据。

解决方案

修补程序信息

现在可以从 Microsoft 获得支持的修补程序。但是,它被用于解决本文中介绍的此问题。它仅应用于出现这一特定问题的系统。此修补程序可能还会接受进一步的测试。因此,如果此问题没有对您造成严重的影响,我们建议您等待包含此修复程序将下一个.net Framework 2.0 service pack。

要立即解决此问题,请联系 Microsoft 客户支持服务以获取此修复程序。有关 Microsoft 客户支持服务电话号码和关于支持费用的信息的完整列表,请访问下面的 Microsoft 网站:
http://support.microsoft.com/contactus/?ws=support
注意 在特殊的情况中如果 Microsoft 支持专业人员确定某个特定更新才能解决您的问题,可能会被取消通常会导致支持电话的费用。将正常收取支持费用将应用于其他支持问题和不需要进行专门更新的问题。

系统必备组件

需要任何先决条件不。

重新启动要求

应用此修补程序后,您必须重新启动计算机。

修补程序替换信息

此修补程序不替代任何其他修补程序。

文件信息

此修补程序的英文版具有的文件属性 (或更新的文件属性) 在下表中列出。日期和时间对这些文件列出在协调世界时 (UTC)。当您查看文件信息时,将转换为本地时间。若要 UTC 与本地时间之间的时差使用控制面板中的日期和时间项中的 时区 选项卡。
收起该表格展开该表格
文件的名称文件版本文件大小日期时间
Mscordacwks.dll2.0.50727.178801,2802006 年七月 8 日11: 28
Mscorlib.dll2.0.50727.1784,317,1842006 年七月 8 日11: 28
Mscorwks.dll2.0.50727.1785,624,3202006 年七月 8 日11: 27
Normalization.dll2.0.50727.17815,3602006 年七月 8 日11: 28
Normidna.nlp不适用59,3422006 年七月 8 日11: 28
Normnfc.nlp不适用45,7942006 年七月 8 日11: 28
Normnfd.nlp不适用39,2842006 年七月 8 日11: 28
Normnfkc.nlp不适用66,3842006 年七月 8 日11: 28
Normnfkd.nlp不适用60,2942006 年七月 8 日11: 28
Sos.dll2.0.50727.178377,3442006 年七月 8 日11: 28
System.data.dll2.0.50727.1782,893,8242006 年七月 8 日11: 28
System.data.oracleclient.dll2.0.50727.178482,3042006 年七月 8 日11: 28

状态

Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。

更多信息

有关详细的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明
有关 OracleDataReader.GetChars 方法的详细信息,请访问下面的 Microsoft 开发人员网络 (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 并单击然后单击 确定
  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,然后单击 确定
  7. 调试 菜单上单击 开始执行 (调试)。

属性

文章编号: 922674 - 最后修改: 2007年12月3日 - 修订: 1.1
这篇文章中的信息适用于:
  • Microsoft .NET Framework 2.0
关键字:?
kbmt kbfix kbbug kbhotfixserver kbqfe kbpubtypekc KB922674 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 922674
Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、间接的、衍生性的损害或任何因使用而丧失所导致的之损害、数据或利润不负任何责任。

提供反馈

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com