我想知道是否可以在每次创建或更新记录时创建一个具有创建日期和更新日期的表。
例如,当我在该表中插入一条记录时,创建日期将自动生成在与更新日期相同的表中。
当我修改这条记录时,创建日期不会改变,但更新日期会根据日期而改变。
非常感谢
我想知道是否可以在每次创建或更新记录时创建一个具有创建日期和更新日期的表。
例如,当我在该表中插入一条记录时,创建日期将自动生成在与更新日期相同的表中。
当我修改这条记录时,创建日期不会改变,但更新日期会根据日期而改变。
非常感谢
CREATE TABLE dbo.foo
(
ID INT IDENTITY(1,1),
CreatedDate DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
UpdatedDate DATETIME NULL
);
GO
CREATE TRIGGER dbo.foo_ForUpdate
ON dbo.foo
FOR UPDATE
AS
BEGIN
SET NOCOUNT ON;
UPDATE f SET UpdatedDate = CURRENT_TIMESTAMP
FROM dbo.foo AS f
INNER JOIN inserted AS i
ON f.ID = i.ID;
END
GO
您可以将列的默认值设置为等于 GetDate(),这会将 Created Date 设置为创建记录的时间。这对 UpdatedDate 不起作用,因为创建记录时将使用默认值。对于此列,您可以使用更新后触发器。这是一个显示如何创建的链接: http ://www.sqlservercurry.com/2010/09/after-update-trigger-in-sql-server.html
触发器是最合适的选择。您可以参考以下触发器示例。
CREATE TRIGGER dbo.TableTriggerName
ON dbo.TableName
AFTER INSERT, UPDATE, DELETE
AS
BEGIN
SET NOCOUNT ON;
--
-- Check if this is an INSERT, UPDATE or DELETE Action.
-- Set Action to Insert by default.
IF EXISTS(SELECT * FROM DELETED)
BEGIN
END
ELSE
IF NOT EXISTS(SELECT * FROM INSERTED) RETURN; -- Nothing updated or inserted.
...
END