All Downloads are FREE. Search and download functionalities are using the official Maven repository.

mq5.0-source.main.mq-broker.persist-jdbc.src.main.java.com.sun.messaging.jmq.jmsserver.persist.jdbc.DBConstants Maven / Gradle / Ivy

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 2000-2012 Oracle and/or its affiliates. All rights reserved.
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License.  You can
 * obtain a copy of the License at
 * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
 * or packager/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at packager/legal/LICENSE.txt.
 *
 * GPL Classpath Exception:
 * Oracle designates this particular file as subject to the "Classpath"
 * exception as provided by Oracle in the GPL Version 2 section of the License
 * file that accompanied this code.
 *
 * Modifications:
 * If applicable, add the following below the License Header, with the fields
 * enclosed by brackets [] replaced by your own identifying information:
 * "Portions Copyright [year] [name of copyright owner]"
 *
 * Contributor(s):
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */

/*
 * @(#)DBConstants.java	1.16 06/29/07
 */ 

package com.sun.messaging.jmq.jmsserver.persist.jdbc;

/**
 * Constants, default values etc.
 * Constants of database table names and column names.
 * Documentation of schema.
 */
public interface DBConstants {

    public static final String SCHEMA_VERSION = "41";
    public static final String SCHEMA_VERSION_40 = "40";

    public static final int HADB_CHUNK_SIZE = 5000;

    /**
     * JDBC table name prefixes and column names for version 370 & 350 tables
     */

    /**
     * Store version:
     * Holds the version of the broker's persistence store.
     *
     * CREATE TABLE IMQSV[37|35] (
     *			STOREVERSION INTEGER,
     *			BROKERID VARCHAR(100)	<- since 350
     */
    public static final String VERSION_TBL_37 = "IMQSV37";
    public static final String VERSION_TBL_35 = "IMQSV35";
    public static final String TVERSION_CVERSION = "STOREVERSION";
    public static final String TVERSION_CBROKERID = "BROKERID";

    /**
     * Configuration change record table:
     * In master broker only. Holds change records for destinations
     * and durables that are propagated around the cluster.
     * One row per record.
     *
     * CREATE TABLE IMQCCREC[37|35] (
     *			RECORDTIME	BIGINT,
     *			RECORD		LONGVARBINARY)
     *
     * RECORDTIME - timestamp when the record was created
     * RECORD - configuration record in serialized form (byte[])
     */
    public static final String CONFIGRECORD_TBL_37 = "IMQCCREC37";
    public static final String CONFIGRECORD_TBL_35 = "IMQCCREC35";
    public static final String TCONFIG_CTIME = "RECORDTIME";
    public static final String TCONFIG_CRECORD = "RECORD";

    /**
     * Destination table:
     * Holds destinations configured on this broker. One row per
     * Destination.
     *
     * CREATE TABLE IMQDEST[37|35] (
     *			DID	VARCHAR(100),
     *			DEST	LONGVARBINARY,
     *			PRIMARY KEY(DID));
     *
     * DID - Unique name of the Destination object
     * DEST - Serialized Destination object
     */
    public static final String DESTINATION_TBL_37 = "IMQDEST37";
    public static final String DESTINATION_TBL_35 = "IMQDEST35";
    public static final String TDEST_CDID = "DID";
    public static final String TDEST_CDEST = "DEST";

    /**
     * Interest table:
     * Holds durable subscriptions. One row per Interest.
     *
     * CREATE TABLE IMQINT[37|35] (
     *			CUID		BIGINT,
     *			INTEREST	LONGVARBINARY,
     *			PRIMARY KEY(CUID));
     *
     * CUID - Long value of the ConsumerUID of the Interest object
     * INTEREST - serialized Interest object
     */
    public static final String INTEREST_TBL_37 = "IMQINT37";
    public static final String INTEREST_TBL_35 = "IMQINT35";
    public static final String TINT_CCUID = "CUID";
    public static final String TINT_CINTEREST = "INTEREST";

    /**
     * Message table:
     * Holds persisted messages. One row per message.
     *
     * CREATE TABLE IMQMSG[37|35] (
     *			MID	VARCHAR(100),
     *			DID	VARCHAR(100),	<- since 350
     *			MSGSIZE	BIGINT,		<- since 350
     *			MSG	LONGVARBINARY,
     *			PRIMARY KEY(MID));
     *
     * MID - Unique name of the SysMessageID of the message packet
     * DID - Unique name of the Destination of this message
     * MSGSIZE - byte count of the message
     * MSG - wire format of the Packet object (the message packet)
     */
    public static final String MESSAGE_TBL_37 = "IMQMSG37";
    public static final String MESSAGE_TBL_35 = "IMQMSG35";
    public static final String TMSG_CMID = "MID";
    public static final String TMSG_CDID = "DID";
    public static final String TMSG_CMSGSIZE = "MSGSIZE";
    public static final String TMSG_CMSG = "MSG";

    /**
     * Property table:
     * General purpose name/value pair. One row per property name/value pair.
     * Used to hold cluster related properties.
     *
     * CREATE TABLE IMQPROPS[37|35] (
     *			PROPNAME	VARCHAR(100),
     *			PROPVALUE	LONGVARBINARY,
     *			PRIMARY KEY(PROPNAME));
     *
     * PROPNAME - property name
     * PROPVALUE - property value; serialized object
     */
    public static final String PROPERTY_TBL_37 = "IMQPROPS37";
    public static final String PROPERTY_TBL_35 = "IMQPROPS35";
    public static final String TPROP_CNAME = "PROPNAME";
    public static final String TPROP_CVALUE = "PROPVALUE";

    /**
     * Interest state table:
     * Associates a message to each interest it was sent to and
     * tracks the acknowledgement state. One row per message/interest pair.
     *
     * CREATE TABLE IMQILIST[37|35] (
     *			MID	VARCHAR(100),
     *			CUID	BIGINT,
     *			DID	VARCHAR(100),	<- since 350
     *			STATE	INTEGER,
     *			PRIMARY KEY(MID, CUID));
     *
     * MID - unique name of the SysMessageID of the message
     * CUID - long value of the ConsumerUID of the interest
     * DID - Unique name of the Destination of the message
     * STATE - state of the interest w.r.t. the message
     */
    public static final String INTEREST_STATE_TBL_37 = "IMQILIST37";
    public static final String INTEREST_STATE_TBL_35 = "IMQILIST35";
    public static final String TINTSTATE_CMID = "MID";
    public static final String TINTSTATE_CCUID = "CUID";
    public static final String TINTSTATE_CDID = "DID";
    public static final String TINTSTATE_CSTATE = "STATE";

    /**
     * Transaction table:
     * Holds all in-progress transactions. One row per transaction.
     *
     * CREATE TABLE IMQTXN[37|35] (
     *			TUID		BIGINT,
     *			STATE		INTEGER,
     *			TSTATEOBJ	LONGVARBINARY,
     *			PRIMARY KEY(TUID));
     *
     * TUID - long value of the UID of the transaction
     * TSTATEOBJ - serialized transaction state object
     * STATE - State of the transaction. This duplicates and is an
     *		optimization of the state filed in the TransactionState
     *		object. This overrides the state field in the
     *		TransactionState object. If its value is -1, then
     *		the transaction has been marked for deletion.
     */
    public static final String TXN_TBL_37 = "IMQTXN37";
    public static final String TXN_TBL_35 = "IMQTXN35";
    public static final String TTXN_CTUID = "TUID";
    public static final String TTXN_CSTATE = "STATE";
    public static final String TTXN_CSTATEOBJ = "TSTATEOBJ";
    public static final int TXN_DELETED = -1;

    /**
     * Transaction Acknowledgement table:
     * Maps Transaction to its pending acknowledgements. One row per
     * transaction UID and acknowledgement pair.
     *
     * CREATE TABLE IMQTACK[37|35] (
     *			TUID	BIGINT,
     *			TXNACK	LONGVARBINARY);
     *
     * TUID - long value of the UID of the transaction
     * TXNACK - serialized TransactionAcknowledgement object
     */
    public static final String TXNACK_TBL_37 = "IMQTACK37";
    public static final String TXNACK_TBL_35 = "IMQTACK35";
    public static final String TTXNACK_CTUID = "TUID";
    public static final String TTXNACK_CACK = "TXNACK";
}

/*
 * EOF
 */




© 2015 - 2024 Weber Informatics LLC | Privacy Policy