PostgreSQL 没有 on update current_timestamp 感觉好麻烦

155 天前
 lucasj

之前一直用 MySQL ,最近一个新项目用的是 PostgreSQL 。

PostgreSQL 没有 on update current_timestamp 只能通过触发器来实现。

这样的话每个表都要创建一个 trigger ,感觉好麻烦。

1980 次点击
所在节点    PostgreSQL
10 条回复
chendy
155 天前
最好还是通过程序实现,事件机制,SQL 拦截器都不错
而且这些机制不仅可以做时间的自动刷新,还可以自动刷新最后修改者之类的

除非有大量直接上数据库手改的数据的需求,否则 on update 这种意义不大
lasuar
155 天前
一般业务开发不建议依赖 db 的触发器或者`on update`机制,因为不够对开发人员来说不够清晰直观,排查问题时需要去检查 db schema 。
ck65
155 天前
确实是个遗憾。不过已经习惯让 ORM 负责这些琐事了,或者在代码逻辑里简单封装一层。
lichao
155 天前
用 ORM 不存在这些问题
adoal
155 天前
想开一点,每个表都要创建一个 trigger ,只是操作上的麻烦一点,而且也只是一次性的。如果你团队里的人都认可这个事应该用数据库的机制做,那就不是啥麻烦。真正的麻烦是,你觉得应该用数据库的机制做,而其它人都觉得:程序员这种生物就应该把所有的事都放在编程的框架里做;程序员这种生物不是 DBA ,不熟悉也不应该熟悉特定数据库的高级 feature ,用编程语言框架才是自己吃饭的工具;咱们的业务虽然 QPS 不到 10 个但是应该按照双 11 的伸缩性不准酱表不准吹歌不准物理外键……相比之下,数据库端自动触发操作是用语法还是用触发器的差别连细节分歧都算不上。
nulIptr
155 天前
@adoal 不得不说世界就是一个圈,古时候上大学的时候讲数据库 3 范式,后面上班了发现即使是最传统的 erp 行业,存储过程能写上百行,都不加外键约束。。。在后面微服务的时候讲起来 join 都不能用了,现在 lz 又倒回去想用数据库特性。
前端也是,古时候 jsp/asp/php 都是服务端渲染,几年 spa 之后,现在又开始 react/vue 服务端渲染。
yangg
155 天前
你用 pg 了再用 mysql 才知道多少东西 mysql 没有的。
635925926
155 天前
每个表本来都要有个序列,不在乎多加个触发器
zbinlin
155 天前
麻烦一点的作法:设置 current_timestamp 列的 default 为 CURRENT_TIMESTAMP ,然后 UPDATE 时 set 下 `current_timestamp = DEFAULT`
dayeye2006199
154 天前
ORM 解千愁,数据库是什么,不存在的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1050830

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX