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

FIX:"并不生成计划程序"可能会发生错误时,使用 CONTAINSTABLE 函数一起使用多个 OR 和 AND 在 SQL Server 2008 中的谓词

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

点击这里察看该文章的英文版: 2344600
Microsoft 分发 Microsoft SQL Server 2008 修复程序作为一个可下载的文件。 该修复程序是累积性的因为每个新版本包含所有修补程序和所有安全修复程序以前的 SQL Server 2008 中包含的修补都程序版本。
症状
请考虑以下情形:
  • 您必须使用全文搜索查询,CONTAINSTABLE与许多一起函数在 Microsoft SQL Server 2008 中条件的谓词。 例如对于您具有以下 50操作:
    Declare @Keywords varchar(4000) = NULLset @Keywords= N'((((((((((((((((((((((((((((((((((((((((((((((((((((("TOKarchitect" OR "architectural") AND ("TOKengineer" OR "engineer")) AND "gineer") AND ("TOKmechanical" OR "Mechanical")) AND ("TOKengineer" OR "Engineering")) AND ("TOKelectronic" OR "Electronics")) AND ("TOKengineer" OR "Engineer")) AND ("TOKelectronic" OR "Electronics")) AND ("TOKengineer" OR "Engineering")) AND ("TOKelectric" OR "Electrical")) AND ("TOKengineer" OR "Engineer")) AND ("TOKelectric" OR "Electrical")) AND ("TOKengineer" OR "Engineering")) AND ("TOKcontrol" OR "Control")) AND ("TOKsystem" OR "Systems")) AND ("TOKengineer" OR "Engineer")) AND ("TOKproject" OR "Project")) AND ("TOKmanager" OR "Manager")) AND ("TOKengineer" OR "Engineering")) AND "Scheme") AND ("TOKmanufacture" OR "Manufacturing")) AND ("TOKengineer" OR "Engineer")) AND ("TOKmetallurgist" OR "Metallurgy")) AND ("TOKmetallurgist" OR "Metallurgist")) AND ("TOKprocess" OR "Process")) AND ("TOKTechnology" OR "Technology")) AND ("TOKproduct" OR "Production")) AND ("TOKengineer" OR "Engineer")) AND ("TOKQuality" OR "Quality")) AND ("TOKengineer" OR "Engineer")) AND ("TOKQuality" OR "Quality")) AND ("TOKcontrol" OR "Control")) AND ("TOKengineer" OR "Engineer")) AND "Mechatronics") AND ("TOKcivil" OR "Civil")) AND ("TOKengineer" OR "Engineer")) AND ("TOKcivil" OR "Civil")) AND ("TOKengineer" OR "Engineering")) AND ("TOKdesign" OR "Design")) AND ("TOKengineer" OR "Engineering")) AND ("TOKdesign" OR "Design")) AND ("TOKengineer" OR "Engineer")) AND ("TOKgraduate" OR "Graduate")) AND ("TOKengineer" OR "Engineer")) AND ("TOKgraduate" OR "Graduate")) AND ("TOKengineer" OR "engineering")) AND ("TOKengineer" OR "Engineering")) AND ("TOKgraduate" OR "Graduate")) AND ") ANDNOT (") AND ("TOKRecruitment" OR "Recruitment")) AND ("TOKconsultant" OR "consultant")) AND ("TOKtrainee" OR "trainee")) AND ("TOKRecruitment" OR "recruitment"))'select * from CONTAINSTABLE(test_table, *, @keywords, 1000) 
  • 在运行查询。
在这种情况下可能出现"并不生成计划程序"错误。 此外,SQL Server 2008 应用程序日志文件夹中生成一个小型转储文件,并在 SQL Server 错误日志文件中记录以下错误:
<time stamp=""></time>服务器使用 dbghelp.dll 版本"4.0.5"
<time stamp=""></time>服务器 *** 无法获取 spid 0 的线程上下文
<time stamp=""></time>服务器 *
*******************************************************************************
<time stamp=""></time>服务器 *
<time stamp=""></time>服务器 * BEGIN 堆栈转储:
<time stamp=""></time>服务器 *<time></time>spid<spid></spid>
<time stamp=""></time>服务器 *
<time stamp=""></time>服务器 * 非并生成计划
<time stamp=""></time>服务器 *
<time stamp=""></time>服务器 *
*******************************************************************************
<time stamp=""></time>服务器堆栈转储签名是 0x000000000000030D
<time stamp=""></time>服务器外部的转储过程返回代码 0x20000001。外部转储过程返回的任何错误。
<time stamp=""></time>服务器进程 0: 0: 0 (0xf94) 工作 0x00000000817481A0 似乎是在调度程序 0 不产生。 线程创建时间: 12925321224306。 约线程 CPU 使用: 内核 62 的 ms 用户 75187 ms.进程利用率 98%。 系统空闲 0%。 间隔: 76403 毫秒。
<time stamp=""></time>服务器进程 0: 0: 0 (0xf94) 工作 0x00000000817481A0 似乎是在调度程序 0 不产生。 线程创建时间: 12925321224306。 约线程 CPU 使用: 内核 125 的 ms 用户 145250 ms.进程利用率 98%。 系统空闲 0%。 间隔: 148417 毫秒。
<time stamp=""></time>服务器进程 0: 0: 0 (0xf94) 工作 0x00000000817481A0 似乎是在调度程序 0 不产生。 线程创建时间: 12925321224306。 约线程 CPU 使用: 内核 171 的 ms 用户 205515 ms.进程利用率 98%。 系统空闲 0%。 间隔: 209729 毫秒。
<time stamp=""></time>服务器进程 0: 0: 0 (0xf94) 工作 0x00000000817481A0 似乎是在调度程序 0 不产生。 线程创建时间: 12925321224306。 约线程 CPU 使用: 内核 218 的 ms 用户 266343 ms.进程利用率 98%。 系统空闲 0%。 间隔: 271588 毫秒。
<time stamp=""></time>服务器进程 0: 0: 0 (0xf94) 工作 0x00000000817481A0 似乎是在调度程序 0 不产生。 线程创建时间: 12925321224306。 约线程 CPU 使用: 内核 234 的 ms 325156 ms.进程利用率 97%的用户。 系统空闲 0%。 间隔: 333671 毫秒。
<time stamp=""></time>服务器进程 0: 0: 0 (0xf94) 工作 0x00000000817481A0 似乎是在调度程序 0 不产生。 线程创建时间: 12925321224306。 约线程 CPU 使用: 内核 296 的 ms 386000 ms.进程利用率 97%的用户。 系统空闲 0%。 间隔: 396370 毫秒。
原因
因为 SQL Server 2008 不正确地释放一个调度程序,将发生此问题。
解决方案

SQL Server 2008 Service Pack 1

在 SQL Server 2008 Service Pack 1 的累积更新 10 首先释放此修复程序以解决此问题。 有关此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2279604对于 SQL Server 2008 Service Pack 1 的累积更新包 10
请注意因为该版本是累积,每个新的修补程序版本包含所有修补程序和所有安全修复程序以前的 SQL Server 2008 中包含的修补都程序版本。 Microsoft 建议您考虑应用最新的修补程序版本包含此修补程序。 有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
970365SQL Server 2008 生成的 SQL Server 2008 Service Pack 1 发布后发布
Microsoft SQL Server 2008 的修复程序会创建特定的 SQL Server 服务包。 必须将 SQL Server 2008 Service Pack 1 修补程序应用到 SQL Server 2008 Service Pack 1 的安装。 默认状态下,SQL Server service pack 中提供的任何修复程序包含在下一个 SQL Server service pack 中。

SQL Server 2008 Service Pack 2

修复此问题的第一次累积更新 1 中发布的 SQL Server 2008 Service Pack 2。 有关此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2289254SQL Server 2008 Service Pack 2 的累积更新 1
请注意因为该版本是累积,每个新的修补程序版本包含所有修补程序和所有安全修复程序以前的 SQL Server 2008 中包含的修补都程序版本。 我们建议您考虑应用最新的修补程序版本包含此修补程序。 有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2402659SQL Server 2008 生成的 SQL Server 2008 Service Pack 2 发布后发布
替代方法
要变通解决此问题,使用以定义谓词的同义词的全文本搜索同义词库。

若要执行此操作使用,FORMSOF一起正常工作了同义词库值,然后添加作为参数的所有关键字。

本示例在"症状"部分中描述的下面就是更新的版本的示例查询:
Select * from test_table where Contains(*,'FORMSOF (THESAURUS,"architectural","engineer","Mechanical","Engineering","Electronics","Engineer","Electrical","Control","Systems","Project","Manager","Manufacturing","Metallurgy","Metallurgist","Process",”Design”,"Technology","Production","Quality","Control","Civil","Graduate","Recruitment","consultant","trainee","recruitment")')
状态
Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。
参考
有关详细信息,CONTAINSTABLE正常工作,请访问下面的 Microsoft 开发人员网络 (MSDN) 网站:为 SQL Server 渐进式的服务模型的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
935897增量服务模型是可从 SQL Server 团队提供报告的问题的修补程序
有关 SQL Server 更新的命名架构的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
822499Microsoft SQL Server 软件更新程序包的新命名架构
有关软件更新术语的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明

警告:本文已自动翻译

属性

文章 ID:2344600 - 上次审阅时间:11/15/2010 19:23:00 - 修订版本: 2.0

Microsoft SQL Server 2008 Developer, Microsoft SQL Server 2008 Enterprise, Microsoft SQL Server 2008 Service Pack 1, Microsoft SQL Server 2008 Standard, Microsoft SQL Server 2008 Standard Edition for Small Business, Microsoft SQL Server 2008 Workgroup

  • kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2344600 KbMtzh
反馈