Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

SQL Server 2005 - Définition d'une colonne en lecture seule

Vous pouvez implémenter un champ "en lecture seule" en créant un déclencheur UPDATE qui vérifie les mises à jour de cette colonne, puis les annule.

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