PostgreSQL如何自动更新时间戳?
这是我参与11月更文挑战的第16天,活动详情查看:2021最后一次更文挑战
🤞 个人主页:@青Cheng序员石头 🤞 粉丝福利:加粉丝群 一对一问题解答,获取免费的丰富简历模板、提高学习资料等,做好新时代的卷卷王!
最近一段时间公司有一些入职的实习生在使用PostgreSQL创建表Schema时,对创建时间
create_at
和更新时间update_at
字段自动更新时间戳不是很清楚。记录这篇文章,让后面来的实习生和新同事有一个参考。
一、为什么
在讲如何更新时间戳之前,我们还是要了解为何有必要自动更新时间戳。对于很多业务表,我们大多数需要记录以下几个字段:
create_at
创建时间update_at
更新时间create_by
创建人update_by
更新人
为了给这些字段赋值,我们需要在repository
层为entity
赋值,创建时间和更新时间就取当前系统时间LocalDateTime
,创建人和更新人需要用系统用户去赋值。对于创建时间和更新时间,这种与当前业务无关的字段,有没有可能不在repository
上每次去手动赋值。
当然,肯定是有的,创建时间无非就是数据新插入行的时间,更新时间就是行数据更新的时间,理解了这一层的含义,那就有解决办法了。
对于Mysql
来说,其内部提供的函数对于创建时间和更新时间的字段的自动更新是相当容易的,但对于PostgreSQL
事情会稍稍复杂一点。
二、如何做
要在插入数据的时候自动填充 create_at
列的值,我们可以使用DEFAULT
值,如下面所示。
CREATE TABLE users (
...
create_at timestamp(6) default current_timestamp
)
为create_at
字段设置一个默认值current_timestamp
当前时间戳,这样达到了通过在 INSERT 语句中提供值来显式地覆盖该列的值。
但上面的这种方式只是对于insert
行数据的时候管用,如果对行更新的时候,我们需要使用到数据库的触发器trigger
。
首先我们编写一个触发器update_modified_column
如下面的代码所示,含义是更新表的字段update_at
为当前时间戳。
CREATE OR REPLACE FUNCTION update_modified_column()
RETURNS TRIGGER AS $$
BEGIN
NEW.update_at = now();
RETURN NEW;
END;
$$ language 'plpgsql';
然后我们应用这个触发器,如何应用呢?当然是为这个触发器设置触发条件。
CREATE TRIGGER update_table_name_update_at BEFORE UPDATE ON table_name FOR EACH ROW EXECUTE PROCEDURE update_modified_column();
即代表的含义是更新表table_name
行数据的时候,执行这个触发器,我们需要为每一个表设置应用这个触发器!至此,达到目的。
少年,没看够?点击石头的详情介绍,随便点点看看,说不定有惊喜呢?欢迎支持点赞/关注/评论,有你们的支持是我更文最大的动力,多谢啦!
转载自:https://juejin.cn/post/7033762606175223839