尝试从链接服务器插入时,当前命令发生严重错误

时间:2018-04-28 14:25:10

标签: sql-server-2008 sql-insert linked-server

我正在使用SQL Server 2008 SP3并尝试从链接服务器插入大约200,000行,但过了一段时间后我收到此错误:

A severe error occurred on the current command.  The results, if any, should be discarded.

发生此错误:

  • 几乎总是,但有时它可以正常工作。
  • 当SELECT仅限于TOP(10)时。
  • 有时当我执行SELECT加入本地表时。

我已经签出了:

  • 我可以在没有JOIN的情况下从链接服务器获取所有行。
  • 在本地和链接服务器上的所有数据库中完成CHECKDB,没有错误。
  • 本地和链接服务器上的所有磁盘中的CHKDSK,没有错误。

这是目标表:

CREATE TABLE [dbo].[TargetTable](
    [ProdID] [varchar](40) NOT NULL,
    [Download] [bigint] NULL,
    [ImageID] [varchar](200) NULL,
    [ImageWeight] [int] NULL,
    [ImageWidth] [int] NULL,
    [ImageHeight] [int] NULL,
    [ImageAngle] [varchar](200) NOT NULL,
    [MfPN] [varchar](40) NOT NULL,
    [ContentGuid] [varchar](200) NOT NULL,
    [MediaTypeID] [int] NOT NULL,
    [MimeType] [varchar](50) NOT NULL,
    [URL] [varchar](500) NOT NULL,
    [Timestamp] [datetime] NULL,
    [_DateLastUpdated] [datetime] NULL
) ON [PRIMARY];

这是我用来插入的查询

INSERT INTO [dbo].[TargetTable]
(
    [ProdID],
    [Download],
    [ImageID],
    [ImageWeight],
    [ImageWidth],
    [ImageHeight],
    [ImageAngle],
    [MfPN],
    [ContentGuid],
    [MediaTypeID],
    [MimeType],
    [URL],
    [Timestamp],
    [_DateLastUpdated]
)
SELECT
    i.ProdID
    ,i.Download
    ,i.ImageID
    ,i.ImageWeight
    ,i.ImageWidth
    ,i.ImageHeight
    ,i.ImageAngle
    ,i.MfPN
    ,i.ContentGuid
    ,i.MediaTypeID
    ,i.MimeType
    ,i.[Url]
    ,i.[Timestamp]
    ,i._DateLastUpdated

FROM [LinkedServer].[Database].[dbo].[view_Source] i WITH(NOLOCK)
    LEFT JOIN [LocalDatabase].[dbo].[TargetTable] t WITH(NOLOCK)
        ON i.ContentGuid = t.ContentGuid AND i.ProdID= t.ProdID
WHERE
    t.ContentGuid IS NULL

感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

在不使用锁的情况下尝试读取也在更改的数据时,可能会发生这种情况。删除 WITH(NOLOCK) 表提示。

即使底层数据没有变化,读取未提交的数据也是有风险的,not recommended

<块引用>

使用 NOLOCK,您可以:

  • 查看两次行
  • 完全跳过行
  • 查看从未提交的数据
  • 并让您的查询因错误而失败
  • 如果您对此很满意,那就太好了 - NOLOCK 适合您。