在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();