-- ----------------------------
|
-- 1、存储每一个已配置的 jobDetail 的详细信息
|
-- ----------------------------
|
drop table if exists qrtz_job_details;
|
CREATE TABLE qrtz_job_details
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
JOB_NAME VARCHAR(200) NOT NULL,
|
JOB_GROUP VARCHAR(200) NOT NULL,
|
DESCRIPTION VARCHAR(250) NULL,
|
JOB_CLASS_NAME VARCHAR(250) NOT NULL,
|
IS_DURABLE BOOL NOT NULL,
|
IS_NONCONCURRENT BOOL NOT NULL,
|
IS_UPDATE_DATA BOOL NOT NULL,
|
REQUESTS_RECOVERY BOOL NOT NULL,
|
JOB_DATA BYTEA NULL,
|
PRIMARY KEY (SCHED_NAME,JOB_NAME,JOB_GROUP)
|
);
|
|
-- ----------------------------
|
-- 2、 存储已配置的 Trigger 的信息
|
-- ----------------------------
|
drop table if exists qrtz_triggers;
|
CREATE TABLE qrtz_triggers
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
TRIGGER_NAME VARCHAR(200) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
JOB_NAME VARCHAR(200) NOT NULL,
|
JOB_GROUP VARCHAR(200) NOT NULL,
|
DESCRIPTION VARCHAR(250) NULL,
|
NEXT_FIRE_TIME BIGINT NULL,
|
PREV_FIRE_TIME BIGINT NULL,
|
PRIORITY INTEGER NULL,
|
TRIGGER_STATE VARCHAR(16) NOT NULL,
|
TRIGGER_TYPE VARCHAR(8) NOT NULL,
|
START_TIME BIGINT NOT NULL,
|
END_TIME BIGINT NULL,
|
CALENDAR_NAME VARCHAR(200) NULL,
|
MISFIRE_INSTR SMALLINT NULL,
|
JOB_DATA BYTEA NULL,
|
PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
|
FOREIGN KEY (SCHED_NAME,JOB_NAME,JOB_GROUP)
|
REFERENCES QRTZ_JOB_DETAILS(SCHED_NAME,JOB_NAME,JOB_GROUP)
|
);
|
-- ----------------------------
|
-- 3、 存储简单的 Trigger,包括重复次数,间隔,以及已触发的次数
|
-- ----------------------------
|
drop table if exists qrtz_simple_triggers;
|
CREATE TABLE qrtz_simple_triggers
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
TRIGGER_NAME VARCHAR(200) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
REPEAT_COUNT BIGINT NOT NULL,
|
REPEAT_INTERVAL BIGINT NOT NULL,
|
TIMES_TRIGGERED BIGINT NOT NULL,
|
PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
|
FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
);
|
-- ----------------------------
|
-- 4、 存储 Cron Trigger,包括 Cron 表达式和时区信息
|
-- ----------------------------
|
drop table if exists qrtz_cron_triggers;
|
CREATE TABLE qrtz_cron_triggers
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
TRIGGER_NAME VARCHAR(200) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
CRON_EXPRESSION VARCHAR(120) NOT NULL,
|
TIME_ZONE_ID VARCHAR(80),
|
PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
|
FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
);
|
|
-- ----------------------------
|
-- 5、 Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候)
|
-- ----------------------------
|
drop table if exists qrtz_blob_triggers;
|
CREATE TABLE qrtz_blob_triggers
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
TRIGGER_NAME VARCHAR(200) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
BLOB_DATA BYTEA NULL,
|
PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
|
FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
);
|
|
-- ----------------------------
|
-- 6、 以 Blob 类型存储存放日历信息, quartz可配置一个日历来指定一个时间范围
|
-- ----------------------------
|
drop table if exists qrtz_calendars;
|
CREATE TABLE qrtz_calendars
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
CALENDAR_NAME VARCHAR(200) NOT NULL,
|
CALENDAR BYTEA NOT NULL,
|
PRIMARY KEY (SCHED_NAME,CALENDAR_NAME)
|
);
|
-- ----------------------------
|
-- 7、 存储已暂停的 Trigger 组的信息
|
-- ----------------------------
|
drop table if exists qrtz_paused_trigger_grps;
|
CREATE TABLE qrtz_paused_trigger_grps
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
PRIMARY KEY (SCHED_NAME,TRIGGER_GROUP)
|
);
|
|
-- ----------------------------
|
-- 8、 存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息
|
-- ----------------------------
|
drop table if exists qrtz_fired_triggers;
|
CREATE TABLE qrtz_fired_triggers
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
ENTRY_ID VARCHAR(95) NOT NULL,
|
TRIGGER_NAME VARCHAR(200) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
INSTANCE_NAME VARCHAR(200) NOT NULL,
|
FIRED_TIME BIGINT NOT NULL,
|
SCHED_TIME BIGINT NOT NULL,
|
PRIORITY INTEGER NOT NULL,
|
STATE VARCHAR(16) NOT NULL,
|
JOB_NAME VARCHAR(200) NULL,
|
JOB_GROUP VARCHAR(200) NULL,
|
IS_NONCONCURRENT BOOL NULL,
|
REQUESTS_RECOVERY BOOL NULL,
|
PRIMARY KEY (SCHED_NAME,ENTRY_ID)
|
);
|
|
-- ----------------------------
|
-- 9、 存储少量的有关 Scheduler 的状态信息,假如是用于集群中,可以看到其他的 Scheduler 实例
|
-- ----------------------------
|
drop table if exists qrtz_scheduler_state;
|
CREATE TABLE qrtz_scheduler_state
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
INSTANCE_NAME VARCHAR(200) NOT NULL,
|
LAST_CHECKIN_TIME BIGINT NOT NULL,
|
CHECKIN_INTERVAL BIGINT NOT NULL,
|
PRIMARY KEY (SCHED_NAME,INSTANCE_NAME)
|
);
|
|
-- ----------------------------
|
-- 10、 存储程序的悲观锁的信息(假如使用了悲观锁)
|
-- ----------------------------
|
drop table if exists qrtz_locks;
|
CREATE TABLE qrtz_locks
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
LOCK_NAME VARCHAR(40) NOT NULL,
|
PRIMARY KEY (SCHED_NAME,LOCK_NAME)
|
);
|
|
drop table if exists qrtz_simprop_triggers;
|
CREATE TABLE qrtz_simprop_triggers
|
(
|
SCHED_NAME VARCHAR(120) NOT NULL,
|
TRIGGER_NAME VARCHAR(200) NOT NULL,
|
TRIGGER_GROUP VARCHAR(200) NOT NULL,
|
STR_PROP_1 VARCHAR(512) NULL,
|
STR_PROP_2 VARCHAR(512) NULL,
|
STR_PROP_3 VARCHAR(512) NULL,
|
INT_PROP_1 INT NULL,
|
INT_PROP_2 INT NULL,
|
LONG_PROP_1 BIGINT NULL,
|
LONG_PROP_2 BIGINT NULL,
|
DEC_PROP_1 NUMERIC(13,4) NULL,
|
DEC_PROP_2 NUMERIC(13,4) NULL,
|
BOOL_PROP_1 BOOL NULL,
|
BOOL_PROP_2 BOOL NULL,
|
PRIMARY KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP),
|
FOREIGN KEY (SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
REFERENCES QRTZ_TRIGGERS(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP)
|
);
|
create index idx_qrtz_j_req_recovery on qrtz_job_details(SCHED_NAME,REQUESTS_RECOVERY);
|
create index idx_qrtz_j_grp on qrtz_job_details(SCHED_NAME,JOB_GROUP);
|
|
create index idx_qrtz_t_j on qrtz_triggers(SCHED_NAME,JOB_NAME,JOB_GROUP);
|
create index idx_qrtz_t_jg on qrtz_triggers(SCHED_NAME,JOB_GROUP);
|
create index idx_qrtz_t_c on qrtz_triggers(SCHED_NAME,CALENDAR_NAME);
|
create index idx_qrtz_t_g on qrtz_triggers(SCHED_NAME,TRIGGER_GROUP);
|
create index idx_qrtz_t_state on qrtz_triggers(SCHED_NAME,TRIGGER_STATE);
|
create index idx_qrtz_t_n_state on qrtz_triggers(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP,TRIGGER_STATE);
|
create index idx_qrtz_t_n_g_state on qrtz_triggers(SCHED_NAME,TRIGGER_GROUP,TRIGGER_STATE);
|
create index idx_qrtz_t_next_fire_time on qrtz_triggers(SCHED_NAME,NEXT_FIRE_TIME);
|
create index idx_qrtz_t_nft_st on qrtz_triggers(SCHED_NAME,TRIGGER_STATE,NEXT_FIRE_TIME);
|
create index idx_qrtz_t_nft_misfire on qrtz_triggers(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME);
|
create index idx_qrtz_t_nft_st_misfire on qrtz_triggers(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME,TRIGGER_STATE);
|
create index idx_qrtz_t_nft_st_misfire_grp on qrtz_triggers(SCHED_NAME,MISFIRE_INSTR,NEXT_FIRE_TIME,TRIGGER_GROUP,TRIGGER_STATE);
|
|
create index idx_qrtz_ft_trig_inst_name on qrtz_fired_triggers(SCHED_NAME,INSTANCE_NAME);
|
create index idx_qrtz_ft_inst_job_req_rcvry on qrtz_fired_triggers(SCHED_NAME,INSTANCE_NAME,REQUESTS_RECOVERY);
|
create index idx_qrtz_ft_j_g on qrtz_fired_triggers(SCHED_NAME,JOB_NAME,JOB_GROUP);
|
create index idx_qrtz_ft_jg on qrtz_fired_triggers(SCHED_NAME,JOB_GROUP);
|
create index idx_qrtz_ft_t_g on qrtz_fired_triggers(SCHED_NAME,TRIGGER_NAME,TRIGGER_GROUP);
|
create index idx_qrtz_ft_tg on qrtz_fired_triggers(SCHED_NAME,TRIGGER_GROUP);
|
commit;
|