首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在PostgreSQL中自动更新时间戳

如何在PostgreSQL中自动更新时间戳
EN

Stack Overflow用户
提问于 2012-03-05 00:08:15
回答 5查看 187.7K关注 0票数 176

我希望代码能够在插入新行时自动更新时间戳,就像我可以使用CURRENT_TIMESTAMP在MySQL中做的那样。

我将如何在PostgreSQL中实现这一点?

代码语言:javascript
复制
CREATE TABLE users (
    id serial not null,
    firstname varchar(100),
    middlename varchar(100),
    lastname varchar(100),
    email varchar(200),
    timestamp timestamp
)
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2012-03-05 00:23:59

要在插入期间填充列,请使用DEFAULT值:

代码语言:javascript
复制
CREATE TABLE users (
  id serial not null,
  firstname varchar(100),
  middlename varchar(100),
  lastname varchar(100),
  email varchar(200),
  timestamp timestamp default current_timestamp
)

请注意,可以通过在INSERT语句中提供一个值来显式覆盖该列的值。如果你想防止这种情况发生,你确实需要一个trigger

如果需要在每次更新行时更新该列,则还需要触发器(作为mentioned by E.J. Brennan)

请注意,对列名使用保留字通常不是一个好主意。您应该找到与timestamp不同的名称

票数 247
EN

Stack Overflow用户

发布于 2014-10-10 01:40:13

更新时间戳,仅当值更改时

基于E.J的链接,并从此链接添加一条if语句(https://stackoverflow.com/a/3084254/1526023)

代码语言:javascript
复制
CREATE OR REPLACE FUNCTION update_modified_column()
RETURNS TRIGGER AS $$
BEGIN
   IF row(NEW.*) IS DISTINCT FROM row(OLD.*) THEN
      NEW.modified = now(); 
      RETURN NEW;
   ELSE
      RETURN OLD;
   END IF;
END;
$$ language 'plpgsql';
票数 71
EN

Stack Overflow用户

发布于 2015-06-07 03:29:01

使用'now()‘作为默认值会自动生成时间戳。

票数 13
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9556474

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档