8623错误:The query processor ran out of internal resources and could not pro

8623错误:The query processor ran out of internal resources and could not produce a query plansql

 

问题描述:express


配置了SQL Server安全性16的告警,发送邮件通知,以下:安全

clip_p_w_picpath001


收到以下告警信息:session

clip_p_w_picpath002


查看错误日志:async

clip_p_w_picpath003

Error: 8623, Severity: 16, State: 1.    
The query processor ran out of internal resources and could not produce a query plan.
ide

 

缘由:sqlserver


这是一个突发事件,预料中只会发生在极其复杂的查询,或者参照了很是大量的表或者分区的查询。好比,使用IN从句(多于10000个条目)SELECT记录。优化

 

解决方法:this


若是是SQL Server 2008 R2及以前版本,使用Server Side Trace;若是是SQL Server 2012及以后版本,使用Extended Event。首先,跟踪到具体致使8623错误的查询。而后对查询进行优化,能够尝试将部分查询结果放到临时表中,而后再去根据条件关联。spa


对于IN从句,咱们能够来看看BOL上的附注部分

Explicitly including an extremely large number of values (many thousands of values separated by commas) within the parentheses, in an IN clause can consume resources and return errors 8623 or 8632. To work around this problem, store the items in the IN list in a table, and use a SELECT subquery within an IN clause.

Error 8623:

The query processor ran out of internal resources and could not produce a query plan. This is a rare event and only expected for extremely complex queries or queries that reference a very large number of tables or partitions. Please simplify the query. If you believe you have received this message in error, contact Customer Support Services for more information.

Error 8632:

Internal error: An expression services limit has been reached. Please look for potentially complex expressions in your query, and try to simplify them.


其余方法:


能够尝试运行带有使用了提示option(force order)、option(hash join)、option(merge join)、option(querytraceon 4102)的计划向导的查询。经过启用跟踪标志4102,将行为转为SQL Server 2000的半链接处理。启用跟踪标志411八、4122(或者涵盖的4199)也能够避免你看到的问题。查看文档肯定你的状况下的具体缘由:

Microsoft Knowledge Base article for TF 4122

Microsoft Knowledge Base article for TF 4102, 4118

Microsoft Knowledge Base article for TF 4199


打相关Hotfix补丁包,或者直接升级到对应版本最新的SP包。相关KB 982376文章:

FIX: A non-yielding scheduler error or an error 8623 occurs when you run a query that contains a large IN clause in SQL Server 2005, SQL Server 2008, or SQL Server 2008 R2

 

使用扩展事件识别8623错误:

 

在SQL Server 2012及后续版本运行如下TSQL脚本:

CREATE EVENT SESSION
overly_complex_queries
ON SERVER
ADD EVENT sqlserver.error_reported
(
ACTION (sqlserver.sql_text, sqlserver.tsql_stack, sqlserver.database_id, sqlserver.username)
WHERE ([severity] = 16
AND [error_number] = 8623)
)
ADD TARGET package0.asynchronous_file_target
(set filename = 'E:\SQL-DATA\XE\overly_complex_queries.xel' ,
metadatafile = 'E:\SQL-DATA\XE\overly_complex_queries.xem',
max_file_size = 10,
max_rollover_files = 5)
WITH (MAX_DISPATCH_LATENCY = 5SECONDS)
GO
-- Start the session
ALTER EVENT SESSION overly_complex_queries
ON SERVER STATE = START
GO


该建立语句若在SQL Server 2008 R2中运行,会报以下错误:

Msg 25706, Level 16, State 8, Line 1

The event attribute or predicate source, "error_number", could not be found.

 

参考:

https://blogs.technet.microsoft.com/mdegre/2012/03/13/8623-the-query-processor-ran-out-of-internal-resources-and-could-not-produce-a-query-plan/

http://dba.stackexchange.com/questions/28945/query-processor-ran-out-of-internal-resources-and-could-not-produce-a-query-plan

https://mssqlwiki.com/2012/10/07/optimizer-timeout-or-optimizer-memory-abort/

http://blog.rdx.com/blog/dba_tips/2014/05/using-server-trace-to-identify-8623-errors

http://jasonbrimhall.info/2014/01/02/day-9-queries-going-boom/

相关文章
相关标签/搜索