Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server 在SQL Server中使用IN语句查询200000行数据_Sql Server - Fatal编程技术网

Sql server 在SQL Server中使用IN语句查询200000行数据

Sql server 在SQL Server中使用IN语句查询200000行数据,sql-server,Sql Server,我正在努力使用SQL中非常大的IN语句查询200000行数据 select CreatedDate from ExchangeAccounts where SamAccountName in ('abc','def','ghi',....., until 200k) 服务器返回一个错误 查询处理器耗尽了内部资源,无法生成查询计划。这是一个罕见的事件,仅适用于非常复杂的查询或引用大量表或分区的查询。请简化查询。如果您认为此消息有误,请联系客户支持服务以获取更多信息 我如何解决这个问题?提前感

我正在努力使用SQL中非常大的IN语句查询200000行数据

select CreatedDate 
from ExchangeAccounts 
where SamAccountName in ('abc','def','ghi',....., until 200k)
服务器返回一个错误

查询处理器耗尽了内部资源,无法生成查询计划。这是一个罕见的事件,仅适用于非常复杂的查询或引用大量表或分区的查询。请简化查询。如果您认为此消息有误,请联系客户支持服务以获取更多信息


我如何解决这个问题?提前感谢

解决此问题的最佳方法是首先将所有200000个字符串作为行放入表中。与使用IN子句相比,SQLServer可以更高效地搜索第二个表。此外,由于IN子句的长度,您会遇到限制

如果无法将200000个字符串作为一个包含200000行的表来源,则此函数可以提供帮助-它将从逗号分隔的列表生成一个表:

CREATE function [dbo].[uParseCSV2Rows](
  @csv varchar(MAX)
)  
returns @table table(Indexkey int         identity(1, 1) primary key,
                     xValue   varchar(200))
as  
BEGIN
  declare @pos int
  select @csv = nullif(ltrim(rtrim(@csv)), '') + ','
  while 1 = 1 and @csv is not null
  begin
    select @pos = charindex(',', @csv)
    if @pos <= 0 break

    insert @table(xValue)
    select left(@csv, @pos - 1)

    select @csv = substring(@csv, @pos+1, len(@csv))
  end
  return
END

不在中列出200k值。您可以先将它们插入一个表中,然后查询它们。如何获取。。。在内容中。?MySQL还是SQL Server?它们是非常不同的产品。没有人说您需要修改表,但您可以在另一个表或临时表中插入200k值并查询。我不确定为什么规则会阻止您使用临时表。你可以使用变量吗?创建一个表变量。我收到一条消息错误,其中在关键字“from”附近显示Msg 156,Level 15,State 1,Line 3语法不正确。如果我仅使用select CreatedDate from ExchangeAccounts,它运行得很好。Ismael,我测试了代码,代码运行正常。您正在运行哪个版本的SQL server?SQL server management studio 2016。不同的版本是否重要?@IsmaelBinAzman SQL的语法取决于服务器,而不是客户端。
select CreatedDate 
from ExchangeAccounts a
where exists (select 1 from dbo.uParseCSV2Rows('abc,def,ghi,...,200k') i where i.xValue = a.SamAccountName)