mirror of https://github.com/dtm-labs/dtm.git
1 changed files with 60 additions and 0 deletions
@ -0,0 +1,60 @@ |
|||||
|
if db_id('dtm') is null |
||||
|
begin |
||||
|
CREATE DATABASE dtm |
||||
|
end; |
||||
|
|
||||
|
drop table IF EXISTS dtm.dbo.trans_global; |
||||
|
CREATE TABLE dtm.dbo.trans_global ( |
||||
|
id bigint NOT NULL IDENTITY, |
||||
|
gid varchar(128) NOT NULL , -- COMMENT 'global transaction id', |
||||
|
trans_type varchar(45) not null , -- COMMENT 'transaction type: saga | xa | tcc | msg', |
||||
|
status varchar(12) NOT NULL , -- COMMENT 'transaction status: prepared | submitted | aborting | succeed | failed', |
||||
|
query_prepared varchar(1024) NOT NULL , -- COMMENT 'url to check for msg|workflow', |
||||
|
protocol varchar(45) not null , -- COMMENT 'protocol: http | grpc | json-rpc', |
||||
|
create_time datetimeoffset DEFAULT NULL, |
||||
|
update_time datetimeoffset DEFAULT NULL, |
||||
|
finish_time datetimeoffset DEFAULT NULL, |
||||
|
rollback_time datetimeoffset DEFAULT NULL, |
||||
|
options varchar(1024) DEFAULT '' , -- COMMENT 'options for transaction like: TimeoutToFail, RequestTimeout', |
||||
|
custom_data varchar(1024) DEFAULT '' , -- COMMENT 'custom data for transaction', |
||||
|
next_cron_interval int default null , -- COMMENT 'next cron interval. for use of cron job', |
||||
|
next_cron_time datetimeoffset default null , -- COMMENT 'next time to process this trans. for use of cron job', |
||||
|
owner varchar(128) not null default '' , -- COMMENT 'who is locking this trans', |
||||
|
ext_data VARCHAR(max) , -- COMMENT 'extra data for this trans. currently used in workflow pattern', |
||||
|
result varchar(1024) DEFAULT '' , -- COMMENT 'result for transaction', |
||||
|
rollback_reason varchar(1024) DEFAULT '' , -- COMMENT 'rollback reason for transaction', |
||||
|
PRIMARY KEY (id), |
||||
|
CONSTRAINT gid UNIQUE (gid) WITH(IGNORE_DUP_KEY = ON) |
||||
|
); |
||||
|
CREATE INDEX[owner] ON [dtm].[dbo].[trans_global]([owner] ASC) |
||||
|
CREATE INDEX[status_next_cron_time] ON [dtm].[dbo].[trans_global]([status] ASC, next_cron_time ASC) ---- COMMENT 'cron job will use this index to query trans' |
||||
|
|
||||
|
drop table IF EXISTS dtm.dbo.trans_branch_op; |
||||
|
CREATE TABLE dtm.dbo.trans_branch_op ( |
||||
|
id bigint NOT NULL IDENTITY, |
||||
|
gid varchar(128) NOT NULL , -- COMMENT 'global transaction id', |
||||
|
url varchar(1024) NOT NULL , -- COMMENT 'the url of this op', |
||||
|
data VARCHAR(max) , -- COMMENT 'request body, depreceated', |
||||
|
bin_data VARBINARY(max) , -- COMMENT 'request body', |
||||
|
branch_id VARCHAR(128) NOT NULL , -- COMMENT 'transaction branch ID', |
||||
|
op varchar(45) NOT NULL , -- COMMENT 'transaction operation type like: action | compensate | try | confirm | cancel', |
||||
|
status varchar(45) NOT NULL , -- COMMENT 'transaction op status: prepared | succeed | failed', |
||||
|
finish_time datetimeoffset DEFAULT NULL, |
||||
|
rollback_time datetimeoffset DEFAULT NULL, |
||||
|
create_time datetimeoffset DEFAULT NULL, |
||||
|
update_time datetimeoffset DEFAULT NULL, |
||||
|
PRIMARY KEY (id), |
||||
|
CONSTRAINT gid_uniq UNIQUE (gid, branch_id, op) |
||||
|
); |
||||
|
drop table IF EXISTS dtm.dbo.kv; |
||||
|
CREATE TABLE dtm.dbo.kv ( |
||||
|
id bigint NOT NULL IDENTITY, |
||||
|
cat varchar(45) NOT NULL , -- COMMENT 'the category of this data', |
||||
|
k varchar(128) NOT NULL, |
||||
|
v VARCHAR(max), |
||||
|
version bigint default 1 , -- COMMENT 'version of the value', |
||||
|
create_time datetimeoffset default NULL, |
||||
|
update_time datetimeoffset DEFAULT NULL, |
||||
|
PRIMARY KEY (id), |
||||
|
CONSTRAINT uniq_k UNIQUE (cat, k) |
||||
|
); |
||||
Loading…
Reference in new issue