在postgres中要实现时间字段更新比较复杂, 不像mysql那样一条DDL语句就能搞定:
---mysql建表语句, update_time
CREATE TABLE `h5_log` (
`id` int unsigned NOT NULL AUTO_INCREMENT,
`template_id` int unsigned NOT NULL COMMENT '活动id',
`param` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT 'H5模板的内容',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`admin_id` int NOT NULL COMMENT '更新人',
PRIMARY KEY (`id`),
) ENGINE=InnoDB AUTO_INCREMENT=2202 DEFAULT CHARSET=utf8mb3 COMMENT='H5日志'
在postgres中需要两步:
- 建表
- 创建时间字段的更新函数
- 创建触发器
1. 建表
CREATE TABLE public.h5_log (
id int
template_id int ,
param longtext character varying,
create_time timestamp not null default(now()) ,
update_time timestamp not null default(now()) ,
admin_id int NOT NULL
)
2. 创建时间字段的更新函数
--每个库创建一次即可
create or replace function upd_timestamp() returns trigger as
$$
begin
new.update_time = current_timestamp;
return new;
end
$$
language plpgsql;
3. 创建触发器
create trigger h5_log_trigger before update on public.h5_log for each row execute procedure upd_timestamp();