Bạn có thể tra cứu tên ràng buộc trong bảng sys.key_constraints:
SELECT name
FROM sys.key_constraints
WHERE [type] = 'PK'
AND [parent_object_id] = Object_id('dbo.Student');
Nếu bạn không quan tâm đến tên, nhưng chỉ muốn bỏ nó, bạn có thể sử dụng kết hợp giữa this và dynamic sql:
DECLARE @table NVARCHAR(512), @sql NVARCHAR(MAX);
SELECT @table = N'dbo.Student';
SELECT @sql = 'ALTER TABLE ' + @table
+ ' DROP CONSTRAINT ' + name + ';'
FROM sys.key_constraints
WHERE [type] = 'PK'
AND [parent_object_id] = OBJECT_ID(@table);
EXEC sp_executeSQL @sql;
Mã này là của Aaron Bertrand (nguồn).