创建一个具有创建日期和更新日期的表(只读)

时间:2013-07-29 16:49:28

标签: sql sql-server-2008 tsql

我想知道每次创建或更新记录时是否可以创建一个具有创建日期和更新日期的表。

例如,当我在该表中插入记录时,创建日期将在表中自动生成,与更新日期相同。

当我修改此记录时,创建日期不会改变,但更新日期将根据日期而改变。

非常感谢

3 个答案:

答案 0 :(得分:4)

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

答案 1 :(得分:2)

您可以将列的默认值设置为等于GetDate(),这会将创建日期设置为创建记录的时间。这对于UpdatedDate不起作用,因为在创建记录时将使用默认值。对于此列,您可以在更新触发器后使用。这是一个显示如何创建一个的链接: http://www.sqlservercurry.com/2010/09/after-update-trigger-in-sql-server.html

答案 2 :(得分:2)

触发器是最合适的选择。您可以按如下方式将样品引用到触发器中。

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

Trigger Reference