我正在使用SQL Server 2008 SP3并尝试从链接服务器插入大约200,000行,但过了一段时间后我收到此错误:
A severe error occurred on the current command. The results, if any, should be discarded.
发生此错误:
我已经签出了:
这是目标表:
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
感谢您的帮助!
答案 0 :(得分:0)
在不使用锁的情况下尝试读取也在更改的数据时,可能会发生这种情况。删除 WITH(NOLOCK) 表提示。
即使底层数据没有变化,读取未提交的数据也是有风险的,not recommended:
<块引用>使用 NOLOCK,您可以: