AntDB 通过扩展 default expression 实现字段值的自动更新

本文探讨了如何通过扩展 PostgreSQL 的 Default Expression 功能来实现在 AntDB 中自动更新字段值,避免使用 TRIGGER。文章介绍了两种方案,重点讲解了方案2,包括扩展 default expression 语法,新增 ColDefaultWhen 规则和 DefaultExpr 数据结构,并验证了字段自动更新及 alter 操作的效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQLON UPDATE CURRENT_TIMESTAMP 带来的启发,AntDB 是否可以实现 UPDATE 时自动更新字段值。

方案
  • 方案1:尝试为需要自动更新的字段自动创建 TRIGGER
  • 方案2:尝试通过 DEFAULT EXPRESSION 来实现字段值的自动更新。
实现
方案1

PostgreSQL之时间戳自动更新

方案2
1. PostgreSQL 默认的 default expression 实现
CREATE TABLE ts (
    id int,
    value int DEFAULT 0,
    tt timestamp DEFAULT current_timestamp
);
2. 查看 pg_attrdef
postgres=# \d ts 
                  Table "public.ts"
 Column |            Type             |   Modifiers   
--------+-----------------------------+---------------
 id     | integer                     | 
 value  | integer                     | default 0
 tt     | timestamp without time zone | default now()

postgres=# select adrelid::regclass, adnum, pg_get_expr(adbin, adrelid) from pg_attrdef where adrelid = 'ts'::regclass ;
 adrelid | adnum | pg_get_expr 
---------+-------+-------------
 ts      |     2 | 0
 ts      |     3 | now()
(2 rows)
3. 扩展 default expression 语法

新增 ColDefaultWhen 规则,对 default expression 修饰,表示 default expression 的生效时机。

DEFAULT b_expr ColDefaultWhen
    {
        Constraint *n = makeNode(Constraint);
        n->contype = CONSTR_DEFAULT;
        n->location = @1;
        n->raw_expr = makeDefaultExpr($3, $2, @2);
        n->cooked_expr = NULL;
        $$ = (Node *)n;
    }

ColDefaultWhen:
            ON INSERT                     { $$ = DEF_ON_INSERT; }
			| ON UPDATE                   { $$ = DEF_ON_UPDATE; }
			| ON INSERT OR UPDATE         { $$ = DEF_ON_INSERT | DEF_ON_UPDATE; }
			|                             { $$ = DEF_ON_INSERT; }
        ;
4. 新增 DefaultExpr 数据结构
/*
 * Default Expression
 */
typedef struct DefaultExpr
{
    NodeTag     type;
    int16       def_when;       /* when to set default expression */
    Node       *def_expr;       /* default expression */
    int         location;       /* token location, or -1 if unknown */
} DefaultExpr;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值