FIX: 当 Visual Studio 数据库设计器向导将放在表名称的前后的括号时,提供程序失败

文章翻译 文章翻译
文章编号: 325790 - 查看本文应用于的产品
本文已归档。它按“原样”提供,并且不再更新。
展开全部 | 关闭全部

本文内容

症状

如果您将一个数据库表从服务器资源管理器拖到一个 WinForm 和您正在使用第三方 OLE DB 提供程序 (包括 IBM DB2 提供程序),您可能会收到以下错误消息:
对于"MyTableName"配置数据适配器时,该向导检测到以下问题。

详细信息:

生成的 Select 语句。

在 Select 子句中的错误: 附近的表达式 [
从子句中的错误: 附近 [
无法分析查询文本。

原因

出现此问题的原因是 Visual Studio 数据库设计器向导创建为是无效的 OleDbDataAdapter SELECT 语句。SELECT 语句具有表名称两边的括号。很多第三方提供程序不支持在表或架构名称的前后的括号,因此该语句将失败。

visual Studio 数据库设计器向导创建类似于下列的 SELECT 语句:
SELECT MySchemaName.[MyTableName].* FROM MySchemaName.[MyTableName]
				

解决方案

服务包信息

若要解决此问题,获得最新的 service pack,Microsoft Visual Studio.net 的。有关详细的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
837234Visual Studio.net 2002 Service Pack 1 中所修复的 bug 的列表

修补程序信息

此 P2 的 P1 版本具有的文件属性 (或更新的文件属性) 在下表中列出。日期和时间对这些文件列出在协调世界时 (UTC)。当您查看文件信息时,将转换为本地时间。若要 UTC 与本地时间之间的时差使用控制面板中的日期和时间工具中的 时区 选项卡。
 Date         Version      Size         File name                Platform
 ------------------------------------------------------------------------
 Jun-27-2002  7.0.9512.0   3,600,384    Microsoft.VSDesigner.dll  x86
				

替代方法

如果在使用 Visual Studio 数据库设计器向导时收到本文"症状"一节中的错误消息,您可以手动更改 SELECT 语句,以解决此问题。若要手动更改 SELECT 语句,请执行下列操作:
  1. Visual Studio 数据库设计器向导中用鼠标右键单击 OleDbDataAdapter,然后选择 属性
  2. 在属性表中展开 SelectCommand,然后单击 $ CommandText
  3. SELECT 语句进行相应更改。visual Studio 数据库设计器将创建以下 SELECT 语句:
    SELECT MySchemaName.[MyTableName].* FROM MySchemaName.[MyTableName]
    					
    更改以下列的语句:
    SELECT MySchemaName.MyTableName.* FROM MySchemaName.MyTableName
    					

状态

Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。 在 Visual Studio.net 2002 Service Pack 1 中,第一次已得到纠正此问题。

属性

文章编号: 325790 - 最后修改: 2013年10月26日 - 修订: 2.1
这篇文章中的信息适用于:
  • Microsoft Visual Studio .NET 2002 专业版
  • Microsoft Visual Studio .NET 2002 企业级结构设计版
  • Microsoft Visual Studio .NET 2002 企业级开发版
关键字:?
kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbvs2002sp1fix kbvs2002sp1sweep kbbug kbfix kbqfe KB325790 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 325790
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