2013-11-20 5 views
-1

Я хочу скопировать данные из таблицы с именем ActionType в базу данных TD_EDD, в другую таблицу с именем ActionType внутри другой базы данных DsVelocity.Ошибка IDENTITY_INSERT при попытке вставить данные в таблицу

Я написал следующий запрос:

INSERT INTO [DsVelocity].[dbo].[ActionType] 
     ([ActionTypeID] 
     ,[ActionTypeName] 
     ,[ActiveStatus]) 
SELECT [ActionTypeID], [ActionType], [Active/Deactive] 
FROM [TD_EDD].[dbo].[ActionType] 
GO 

Всякий раз, когда я пытаюсь сделать это, я получаю следующее сообщение об ошибке:

Msg 544, Level 16, State 1, Line 1 
Cannot insert explicit value for identity column in table 'ActionType' when IDENTITY_INSERT is set to OFF. 

Я не понимаю, что случилось, и почему я получаю эту ошибку?

Обратите внимание, что я использую Microsoft SQL Server 2008 R2.

ответ

1

Это означает, что когда вы вставляете данные в таблицу целей, у вас будут конфликтующие идентификаторы. Скорее всего, колонка ActionTypeId

исправить это использовать

INSERT INTO [DsVelocity].[dbo].[ActionType] 
     ([ActionTypeName] 
     ,[ActiveStatus]) 
SELECT [ActionType], [Active/Deactive] 
FROM [TD_EDD].[dbo].[ActionType] 
GO 
+0

Я думаю, что это был самый краткий и подходящий ответ на мой вопрос. Благодарю. –

+0

Важно, что он работает – evhen14

+0

Теперь он работает отлично. Спасибо вам всем!!!!! –

0

Ну, предположим из сообщения, что ActionTypeID является IDENTITY Column. Вы не можете isert значения в этом столбце, как это автоматически генерировать, uless использовать IDENTITY_INSERT

Allows explicit values to be inserted into the identity column of a table.

At any time, only one table in a session can have the IDENTITY_INSERT property set to ON. If a table already has this property set to ON, and a SET IDENTITY_INSERT ON statement is issued for another table, SQL Server returns an error message that states SET IDENTITY_INSERT is already ON and reports the table it is set ON for.

If the value inserted is larger than the current identity value for the table, SQL Server automatically uses the new inserted value as the current identity value.

The setting of SET IDENTITY_INSERT is set at execute or run time and not at parse time.

Таким образом, вы должны сделать что-то вроде

SET IDENTITY_INSERT [DsVelocity].[dbo].[ActionType] ON 

перед вставкой.

+1

И затем SET IDENTITY_INSERT [DsVelocity]. [DBO]. [ActionType] OFF после вставки. –

+0

Да, я понятия не имел о запросе IDENTITY_INSERT и его основных функциях. Ваш ответ помог мне понять концепцию. Большое спасибо за ваше время и терпение, чтобы ответить на мой вопрос. –

Смежные вопросы