Home > SQL Server Error Messages > Msg 2627 - Violation of PRIMARY KEY constraint Constraint Name. Cannot insert duplicate key in object Table Name. |
SQL Server Error Messages - Msg 2627 - Violation of PRIMARY KEY constraint Constraint Name. Cannot insert duplicate key in object Table Name. |
Server: Msg 2627, Level 14, State 1, Line 1
Violation of PRIMARY KEY constraint Constraint Name.
Cannot insert duplicate key in object Table Name.
This error occurs when you are trying to insert a new row into a table that contains a PRIMARY KEY
constraint and the key of the row being inserted already exists in the table. As an example, suppose you have a table containing the different currency codes:
CREATE TABLE [dbo].[Currency] (
[CurrencyCode] VARCHAR(3) NOT NULL PRIMARY KEY,
[CurrencyName] VARCHAR(50) NOT NULL
)
GO
INSERT INTO [dbo].[Currency] ( [CurrencyCode], [CurrencyName] )
VALUES ( 'CAD', 'Canadian Dollar' ),
( 'CHF', 'Swiss Franc' ),
( 'EUR', 'Euro' ),
( 'GBP', 'Pound Sterling' ),
( 'JPY', 'Yen' ),
( 'KRW', 'Won' ),
( 'USD', 'U.S. Dollar' )
GO
SELECT * FROM [dbo].[Currency]
GO
| CurrencyCode | CurrencyName | |--------------|-----------------| | CAD | Canadian Dollar | | CHF | Swiss Franc | | EUR | Euro | | GBP | Pound Sterling | | JPY | Yen | | KRW | Won | | USD | U.S. Dollar |
Figure 1: Error Message 2627 - [dbo].[Currency] Table
And you have another table, [dbo].[CountryCurrency]
, that contains the different countries and their corresponding currency code.
CREATE TABLE [dbo].[CountryCurrency] (
[Country] VARCHAR(50) NOT NULL,
[CurrencyCode] VARCHAR(3) NOT NULL,
[CurrencyName] VARCHAR(50) NOT NULL
)
GO
INSERT INTO [dbo].[CountryCurrency] ( [Country], [CurrencyCode], [CurrencyName] )
VALUES ( 'Argentina', 'ARS', 'Argentina Peso' ),
( 'Australia', 'AUD', 'Australian Dollar' ),
( 'Austria', 'EUR', 'Euro' ),
( 'Brazil', 'BRL', 'Brazilian Real' ),
( 'China', 'CNY', 'Yuan Renminbi' ),
( 'India', 'INR', 'Indian Rupee' ),
( 'Netherlands', 'EUR', 'Euro' ),
( 'Panama', 'USD', 'U.S. Dollar' ),
( 'Puerto Rico', 'USD', 'U.S. Dollar' ),
( 'Philippines', 'PHP', 'Philippine Peso' ),
( 'Tuvalu', 'AUD', 'Australian Dollar' )
GO
SELECT * FROM [dbo].[CountryCurrency]
GO
| Country | CurrencyCode | CurrencyName | |-------------|--------------|-------------------| | Argentina | ARS | Argentina Peso | | Australia | AUD | Australian Dollar | | Austria | EUR | Euro | | Brazil | BRL | Brazilian Real | | China | CNY | Yuan Renminbi | | India | INR | Indian Rupee | | Netherlands | EUR | Euro | | Panama | USD | U.S. Dollar | | Puerto Rico | USD | U.S. Dollar | | Philippines | PHP | Philippine Peso | | Tuvalu | AUD | Australian Dollar |
Figure 2: Error Message 2627 - [dbo].[CountryCurrency] Table
You want to add into the [dbo].[Currency]
table all the currencies defined in the [dbo].[CountryCurrency]
as follows:
INSERT INTO [dbo].[Currency] ( [CurrencyCode], [CurrencyName] )
SELECT [CurrencyCode], [CurrencyName]
FROM [dbo].[CountryCurrency]
GO
Since some of the currencies in the [dbo].[CountryCurrency]
already exists in the [dbo].[Currency]
table, such as EUR for Euro and USD for U.S. Dollar, the following error is encountered:
Server: Msg: 2627, Line 1, State: 1, Level: 14
Violation of PRIMARY KEY constraint 'PK__Currency__408426BE0016E031'.
Cannot insert duplicate key in object 'dbo.Currency'.
The duplicate key value is (EUR).
Msg: 3621, Line 1, State: 0, Level: 0
The statement has been terminated.
Figure 3: Error Message 2627 - Violation of PRIMARY KEY Constraint - EUR
To avoid this error, add a condition in the SELECT statement to only include currency codes that does not yet exist in the [dbo].[Currency]
table:
INSERT INTO [dbo].[Currency] ( [CurrencyCode], [CurrencyName] )
SELECT [CurrencyCode], [CurrencyName]
FROM [dbo].[CountryCurrency] cc
WHERE NOT EXISTS (SELECT 'X' FROM [dbo].[Currency] c
WHERE cc.[CurrencyCode] = c.[CurrencyCode])
GO
But since there are 2 rows in the [dbo].[CountryCurrency]
that is using the same currency, namely AUD for the Australian Dollar, even though this currency does not yet exist in the [dbo].[Currency]
table, a similar error is generated:
Server: Msg: 2627, Line 1, State: 1, Level: 14
Violation of PRIMARY KEY constraint 'PK__Currency__408426BE0016E031'.
Cannot insert duplicate key in object 'dbo.Currency'.
The duplicate key value is (AUD).
Msg: 3621, Line 1, State: 0, Level: 0
The statement has been terminated.
Figure 4: Error Message 2627 - Violation of PRIMARY KEY Constraint - AUD
This error can be overcome by adding the DISTINCT
clause in the SELECT
query:
INSERT INTO [dbo].[Currency] ( [CurrencyCode], [CurrencyName] )
SELECT DISTINCT [CurrencyCode], [CurrencyName]
FROM [dbo].[CountryCurrency] cc
WHERE NOT EXISTS (SELECT 'X' FROM [dbo].[Currency] c
WHERE cc.[CurrencyCode] = c.[CurrencyCode])
GO
SELECT * FROM [dbo].[Currency]
GO
| CurrencyCode | CurrencyName | |--------------|-------------------| | ARS | Argentina Peso | | AUD | Australian Dollar | | BRL | Brazilian Real | | CAD | Canadian Dollar | | CHF | Swiss Franc | | CNY | Yuan Renminbi | | EUR | Euro | | GBP | Pound Sterling | | INR | Indian Rupee | | JPY | Yen | | KRW | Won | | PHP | Philippine Peso | | USD | U.S. Dollar |
Figure 5: Error Message 2627 - Solution