V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
lucasj
V2EX  ›  PostgreSQL

PostgreSQL 没有 on update current_timestamp 感觉好麻烦

  •  
  •   lucasj · 7 天前 · 1128 次点击

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

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

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

    10 条回复    2024-06-19 23:24:00 +08:00
    chendy
        1
    chendy  
       7 天前
    最好还是通过程序实现,事件机制,SQL 拦截器都不错
    而且这些机制不仅可以做时间的自动刷新,还可以自动刷新最后修改者之类的

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