【问题标题】:get data from a linked server using a loop使用循环从链接服务器获取数据
【发布时间】:2019-10-23 14:10:52
【问题描述】:

在我的数据库中是一个表 TodayID 一个表包含更多 400000 行,我正在寻找一种方法/示例,以使用循环 While,With 每个 ID 将数据从链接服务器加载到 DB MSSQL 中。 我使用 IN 但使用 EXEC AT 时出现错误“openquery more than 8000 characters”,调整 RPC,RPC out 并没有解决问题。

DECLARE @SQL VARCHAR(MAX)
DECLARE @ID  VARCHAR(MAX)
DECLARE @resTable TABLE(ID VARCHAR(50), NAME VARCHAR(100), DTIME DATETIME, FIELD VARCHAR(100))
SET @ID = (STUFF((SELECT ',' + '''''' + [ID] + '''''' FROM [TodayID] FOR XML PATH('')) ,1,1,'') )  
Print @ID
SET @SQL='SELECT * FROM OPENQUERY(RemoteServer, ''SELECT ID, NAME, DTIME, FIELD FROM AUDIT WHERE ID IN (' + @ID + ')  '')'
Print @SQL
INSERT INTO @resTable EXEC (@SQL)
select * from @resTable

【问题讨论】:

  • 你为什么要首先使用WHILE
  • 你可以只做一个 4 部分的名称,然后在本地 select * from 中进行一次插入,而不需要任何这些,不是吗?

标签: sql sql-server linked-server openquery


【解决方案1】:

如果您想通过 WHILE 循环 读取表行,以下查询将为您提供帮助。但是 ID 列的值必须是有序的。

DECLARE @SQL VARCHAR(MAX)
DECLARE @ID  VARCHAR(MAX)
DECLARE @Counter AS INT
DECLARE @MaxCounter AS INT

DECLARE @resTable TABLE(ID VARCHAR(50), NAME VARCHAR(100), DTIME DATETIME, FIELD VARCHAR(100))
--SET @ID = (STUFF((SELECT ',' + '''''' + [ID] + '''''' FROM [TodayID] FOR XML PATH('')) ,1,1,'') )  

SELECT @Counter = MIN(ID) FROM [TodayID]
SELECT @MaxCounter=MAX(ID) FROM [TodayID]

WHILE(@Counter IS NOT NULL
      AND @Counter <= @MaxCounter)

      BEGIN
SET @SQL='SELECT * FROM OPENQUERY(RemoteServer, ''SELECT ID, NAME, DTIME, FIELD FROM AUDIT WHERE ID IN (' + CONVERT(VARCHAR,@Counter) + ')  '
Print @SQL
INSERT INTO @resTable EXEC (@SQL)
SET @Counter  = @Counter  + 1        --According to your id gap
END
select * from @resTable

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-12-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-08-04
    • 1970-01-01
    相关资源
    最近更新 更多