dbscripts.derby-mb.sql Maven / Gradle / Ivy
/*
* Copyright (c) 2017, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
*
* WSO2 Inc. licenses this file to you under the Apache License,
* Version 2.0 (the "License"); you may not use this file except
* in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
-- WSO2 Message Broker Derby Database schema --
-- Start of Message Store Tables --
CREATE TABLE MB_EXCHANGE (
EXCHANGE_NAME VARCHAR(256) NOT NULL,
EXCHANGE_TYPE VARCHAR(256) NOT NULL,
PRIMARY KEY(EXCHANGE_NAME)
);
CREATE TABLE MB_QUEUE_METADATA (
QUEUE_NAME VARCHAR(256) NOT NULL,
QUEUE_ARGUMENTS BLOB(2048) NOT NULL,
PRIMARY KEY (QUEUE_NAME)
);
CREATE TABLE MB_BINDING (
EXCHANGE_NAME VARCHAR(256) NOT NULL,
QUEUE_NAME VARCHAR(256) NOT NULL,
ROUTING_KEY VARCHAR(256) NOT NULL,
ARGUMENTS BLOB(2048) NOT NULL,
-- Cant add ARGUMENTS as a primary key since its a blob
PRIMARY KEY (EXCHANGE_NAME, QUEUE_NAME, ROUTING_KEY),
FOREIGN KEY (EXCHANGE_NAME) REFERENCES MB_EXCHANGE (EXCHANGE_NAME) ON DELETE CASCADE,
FOREIGN KEY (QUEUE_NAME) REFERENCES MB_QUEUE_METADATA (QUEUE_NAME) ON DELETE CASCADE
);
CREATE TABLE MB_METADATA (
MESSAGE_ID BIGINT,
EXCHANGE_NAME VARCHAR(256) NOT NULL,
ROUTING_KEY VARCHAR(256) NOT NULL,
CONTENT_LENGTH BIGINT NOT NULL,
MESSAGE_METADATA BLOB(65500) NOT NULL,
PRIMARY KEY (MESSAGE_ID)
);
CREATE TABLE MB_CONTENT (
MESSAGE_ID BIGINT,
CONTENT_OFFSET INTEGER,
MESSAGE_CONTENT BLOB(65500) NOT NULL,
PRIMARY KEY (MESSAGE_ID, CONTENT_OFFSET),
FOREIGN KEY (MESSAGE_ID) REFERENCES MB_METADATA (MESSAGE_ID)
ON DELETE CASCADE
);
CREATE TABLE MB_QUEUE_MAPPING (
QUEUE_NAME VARCHAR(256) NOT NULL,
MESSAGE_ID BIGINT,
PRIMARY KEY (MESSAGE_ID, QUEUE_NAME),
FOREIGN KEY (MESSAGE_ID) REFERENCES MB_METADATA (MESSAGE_ID)
ON DELETE CASCADE,
FOREIGN KEY (QUEUE_NAME) REFERENCES MB_QUEUE_METADATA (QUEUE_NAME)
ON DELETE CASCADE
);
INSERT INTO MB_EXCHANGE (EXCHANGE_NAME, EXCHANGE_TYPE) VALUES('<>', 'direct');
INSERT INTO MB_EXCHANGE (EXCHANGE_NAME, EXCHANGE_TYPE) VALUES('amq.dlx', 'direct');
INSERT INTO MB_EXCHANGE (EXCHANGE_NAME, EXCHANGE_TYPE) VALUES('amq.direct', 'direct');
INSERT INTO MB_EXCHANGE (EXCHANGE_NAME, EXCHANGE_TYPE) VALUES('amq.topic', 'topic');
CREATE TABLE MB_COORDINATOR_HEARTBEAT (
ANCHOR INT NOT NULL,
NODE_ID VARCHAR(512) NOT NULL,
LAST_HEARTBEAT BIGINT NOT NULL,
PRIMARY KEY (ANCHOR)
);
CREATE TABLE MB_NODE_HEARTBEAT (
NODE_ID VARCHAR(512) NOT NULL,
LAST_HEARTBEAT BIGINT NOT NULL,
IS_NEW_NODE SMALLINT NOT NULL,
PRIMARY KEY (NODE_ID)
);
© 2015 - 2025 Weber Informatics LLC | Privacy Policy