你目前正处于脱机状态,正在等待 Internet 重新连接

当您在 Microsoft SQL Server 2005 中运行 DBCC CHECKTABLE 语句或 DBCC CHECKDB 语句时 FIX: 错误消息:"列 <columnname>值超出范围数据类型浮动是"

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

点击这里察看该文章的英文版: 942904
错误: # 50001847 (SQL 修补程序)
Microsoft 将 Microsoft SQL Server 2005 修补程序分发作为一个可下载的文件。因为该修补程序是累积性的因此每个新版本包含的所有修补程序和所有安全修补程序附带以前 SQL Server 2005 修补都程序版本。
症状
Microsoft SQL Server 2005,运行 DBCC CHECKTABLE 语句或 DBCC CHECKDB 语句,以执行一个表上的物理一致性检查时您将收到一条错误消息,类似于以下错误消息:
对于 <tablename>DBCC 结果。
消息 2570 级别 16 状态 3 行 1 页 (1:73) 插槽 2 对象 ID 2073058421 索引 ID 1 分区 ID 72057594038321152 分配单位 ID 72057594043301888 (类型"行中的数据") 中。列"<columnname>"的值超出了数据类型"浮动"的范围。 更新为合法值的列。
注意此错误信息中 TableName 值,该值代表实际的表名称和 ColumnName 值,该值代表列的实际名称。
原因
出现此问题的原因是一个 INSERT 语句或 UPDATE 语句将传递到是 FLOAT 数据类型列的列的范围内的值。如果 INSERT 语句或 UPDATE 语句不会发送的插入或更新的值为文本,可能会发生这种情况。例如对于如果您使用某个变量以传递到一个 INSERT 语句或 UPDATE 语句中的无效值可能会出现此问题。
解决方案
在累积更新 4 第一次释放此问题的修复程序。有关如何获取 SQL Server 2005 Service Pack 2 的此累积更新包的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
941450对于 SQL Server 2005 Service Pack 2 的累积更新包 4
注意因为这些版本是累积性的因此每个新的修补程序版本包含的所有修补程序和所有安全修补程序附带以前 SQL Server 2005 修补都程序版本。Microsoft 建议您考虑应用最新的修补程序版本包含此修补程序。有关详细的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
937137SQL Server 2005 生成发布 SQL Server 2005 Service Pack 2 之后发布的
为特定 SQL Server 服务包创建 Microsoft SQL Server 2005 修补程序。必须将 SQL Server 2005 Service Pack 2 修补程序应用到 SQL Server 2005 Service Pack 2 的安装。默认状态下,SQL Server service pack 中提供的任何修补程序包含在下一个 SQL Server 服务包中。

有关哪些文件发生更改的详细信息,并应用累积更新包包含此 Microsoft 知识库文章中描述的修补程序的任何系统必备项有关的信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
941450对于 SQL Server 2005 Service Pack 2 的累积更新包 4
状态
Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。
更多信息
应用此修补程序后,SQL Server 不会阻止您在 FLOAT 数据类型列中输入无效值。应用此修补程序后,无效的值不表示为 DBCC CHECKTABLE 语句中或 DBCC CHECKDB 语句中的错误。

重现此问题的步骤

  1. 打开 SQL Server 管理 Studio,然后连接到 SQL Server 2005 实例。
  2. 创建一个新的查询,然后运行下面的语句:
    create table tb1 (c float)godeclare @f floatset @f=1E-307*0.01insert tb1 values (@f)goselect * from tb1go
    公告以下无效的值已被插入到表:
    1e 309
  3. 运行下列语句:
    DBCC CHECKTABLE ('tb1')go
    收到"症状"部分描述的错误消息。
  4. 运行下列语句:
    insert tb1 values (1E-309)go
    您会收到下面的消息取决于 SQL Server 生成之一:

    消息 1
    警告: 在浮点值"1E-309 ' 太小。它将被解释为 0。
    消息 2
    浮点值"1E-309"是计算机表示形式 (8 个字节) 的范围内。
    在这种情况下无效的值是未插入到表因为作为文本发送值。
  5. 运行下列语句以检查在步骤 4 中在表中插入的值:
    select * from tb1go
    公告 0 插入,而不是无效值。
参考
有关如何解决 DBCC 错误 2750 (数据纯度) 的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
923247故障排除 DBCC 错误 2570 SQL Server 2005 中
有关列表后 SQL Server Service Pack 2 的可用版本的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
937137SQL Server 2005 生成发布 SQL Server 2005 Service Pack 2 之后发布的
对于 SQL Server 增量的服务模型的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
935897一个增量的服务模型是可从 SQL Server 团队提供报告的问题的修补程序
有关如何获取 SQL Server 2005 Service Pack 2 的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
913089如何获取最新的 service pack,SQL Server 2005 年
有关新功能和 SQL Server 2005 Service Pack 2 中的改进的详细信息请访问下面的 Microsoft 网站:有关命名 SQL Server 更新架构的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
822499Microsoft SQL Server 软件更新程序包的新命名架构
有关软件更新术语的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明

警告:本文已自动翻译

属性

文章 ID:942904 - 上次审阅时间:11/14/2007 19:40:35 - 修订版本: 2.4

Microsoft SQL Server 2005 Standard Edition, Microsoft SQL Server 2005 Developer Edition, Microsoft SQL 2005 Server Enterprise, Microsoft SQL Server 2005 Enterprise X64 Edition, Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems, Microsoft SQL Server 2005 Standard X64 Edition, Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems

  • kbmt kbsql2005engine kbhotfixrollup kbfix kbpubtypekc kbqfe kbexpertiseadvanced KB942904 KbMtzh
反馈