Msg 1786, Level 16, State 0, Line 1
Either column ‘%.*ls.%.*ls’ or referencing column ‘%.*ls.%.*ls’ in foreign key ‘%.*ls’ is a timestamp column. This data type cannot be used with cascading referential integrity constraints.
This error message appears when you try to create a cascading referential integrity operation for a column of the TIMESTAMP data type.
The T-SQL statement can be parsed, but causes the error at runtime.
Error of the Severity Level 16 are generated by the user and can be fixed by the SQL Server user. The statement cannot be executed this way. Cascading referential integrity operations cannot be created for columns of that data type.
All versions of SQL Server.
IF OBJECT_ID(‘tempdb..t1’) > 0
DROP TABLE t1
IF OBJECT_ID(‘tempdb..t’) > 0
DROP TABLE t
CREATE TABLE t
c1 TIMESTAMP PRIMARY KEY
CREATE TABLE t1
CONSTRAINT FK_t_t1_c1 FOREIGN KEY REFERENCES t(c1)
ON UPDATE CASCADE
In the above example we try to create the referential integrity operation ON UPDATE CASCADE for a column of the data type TIMESTAMP. This raises the error.