Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

SQL Server 2005 - Impostazione di una colonna in sola lettura

Puoi implementare un campo di "sola lettura" creando un trigger UPDATE che verifica la presenza di aggiornamenti in quella colonna e poi li ripristina.

IF EXISTS (SELECT name FROM sys.objects
      WHERE name = 'ReadOnlyInsertTime_tr' AND type = 'TR')
   DROP TRIGGER dbo.ReadOnlyInsertTime_tr;
GO

CREATE TRIGGER ReadOnlyInsertTime_tr
ON dbo.MyTable
AFTER UPDATE 
AS 
IF (UPDATE(InsertTime))
BEGIN
ROLLBACK
-- Raise an informative error
-- RAISERROR (50009, 16, 10)
END;
GO