Delete Primary Keys


Applies To: SQL Server 2016

THIS TOPIC APPLIES TO: yesSQL Server (starting with 2016)yesAzure SQL DatabaseyesAzure SQL Data Warehouse yesParallel Data Warehouse

You can delete (drop) a primary key in SQL Server 2016 by using SQL Server Management Studio or Transact-SQL. When the primary key is deleted, the corresponding index is deleted.

In This Topic



Requires ALTER permission on the table.

To delete a primary key constraint using Object Explorer

  1. In Object Explorer, expand the table that contains the primary key and then expand Keys.

  2. Right-click the key and select Delete.

  3. In the Delete Object dialog box, verify the correct key is specified and click OK.

To delete a primary key constraint using Table Designer

  1. In Object Explorer, right-click the table with the primary key, and click Design.

  2. In the table grid, right-click the row with the primary key and choose Remove Primary Key to toggle the setting from on to off.

    System_CAPS_ICON_note.jpg Note

    To undo this action, close the table without saving the changes. Deleting a primary key cannot be undone without losing all other changes made to the table.

  3. On the File menu, click Savetable name.

To delete a primary key constraint

  1. In Object Explorer, connect to an instance of Database Engine.

  2. On the Standard bar, click New Query.

  3. Copy and paste the following example into the query window and click Execute. The example first identifies the name of the primary key constraint and then deletes the constraint.

    USE AdventureWorks2012;  
    -- Return the name of primary key.  
    SELECT name  
    FROM sys.key_constraints  
    WHERE type = 'PK' AND OBJECT_NAME(parent_object_id) = N'TransactionHistoryArchive';  
    -- Delete the primary key constraint.  
    ALTER TABLE Production.TransactionHistoryArchive  
    DROP CONSTRAINT PK_TransactionHistoryArchive_TransactionID;   

For more information, see ALTER TABLE (Transact-SQL) and sys.key_constraints (Transact-SQL)

Community Additions