pgsql创建表,设置自增id

CREATE TABLE "public"."day_config" (
  "id" int4 NOT NULL DEFAULT nextval('day_config_id_seq'::regclass),
  "year" varchar(255) COLLATE "pg_catalog"."default",
  "month" varchar(255) COLLATE "pg_catalog"."default",
  "week" varchar(255) COLLATE "pg_catalog"."default",
  "day" varchar(255) COLLATE "pg_catalog"."default",
  "quarter" varchar(255) COLLATE "pg_catalog"."default",
  "last_year" varchar(255) COLLATE "pg_catalog"."default",
  "last_month" varchar(255) COLLATE "pg_catalog"."default",
  "last_week" varchar(255) COLLATE "pg_catalog"."default",
  "last_quarter" varchar(255) COLLATE "pg_catalog"."default",
  "create_time" timestamp(6),
  CONSTRAINT "day_config_pkey" PRIMARY KEY ("id")
)
;

ALTER TABLE "public"."day_config" 
  OWNER TO "postgres";

CREATE TRIGGER "set_day_config_id" BEFORE INSERT ON "public"."day_config"
FOR EACH ROW
EXECUTE PROCEDURE "public"."trigger_set_id"();

COMMENT ON COLUMN "public"."day_config"."year" IS '年';

COMMENT ON COLUMN "public"."day_config"."month" IS '月';

COMMENT ON COLUMN "public"."day_config"."week" IS '周';

COMMENT ON COLUMN "public"."day_config"."day" IS '日';

COMMENT ON COLUMN "public"."day_config"."quarter" IS '季度';

COMMENT ON COLUMN "public"."day_config"."last_year" IS '是否是年的最后一天';

COMMENT ON COLUMN "public"."day_config"."last_month" IS '是否是月的最后一天';

COMMENT ON COLUMN "public"."day_config"."last_week" IS '是否是周的最后一天';

COMMENT ON COLUMN "public"."day_config"."last_quarter" IS '是否是季度的最后一天';

COMMENT ON COLUMN "public"."day_config"."create_time" IS '创建时间';

创建序列

-----创建序列
CREATE SEQUENCE day_config_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;



------- 创建触发器函数
CREATE OR REPLACE FUNCTION trigger_set_id()
RETURNS TRIGGER AS $$
BEGIN
    NEW.id := NEXTVAL('day_config_id_seq');
    RETURN NEW;
END;
$$ LANGUAGE plpgsql;



-- 创建触发器,在新行插入之前调用函数
CREATE TRIGGER set_day_config_id
BEFORE INSERT ON "public"."day_config"
FOR EACH ROW
EXECUTE FUNCTION trigger_set_id();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值