⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 constraint.java

📁 一个用java写的开源的数据库系统
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* Copyrights and Licenses * * This product includes Hypersonic SQL. * Originally developed by Thomas Mueller and the Hypersonic SQL Group.  * * Copyright (c) 1995-2000 by the Hypersonic SQL Group. All rights reserved.  * Redistribution and use in source and binary forms, with or without modification, are permitted * provided that the following conditions are met:  *     -  Redistributions of source code must retain the above copyright notice, this list of conditions *         and the following disclaimer.  *     -  Redistributions in binary form must reproduce the above copyright notice, this list of *         conditions and the following disclaimer in the documentation and/or other materials *         provided with the distribution.  *     -  All advertising materials mentioning features or use of this software must display the *        following acknowledgment: "This product includes Hypersonic SQL."  *     -  Products derived from this software may not be called "Hypersonic SQL" nor may *        "Hypersonic SQL" appear in their names without prior written permission of the *         Hypersonic SQL Group.  *     -  Redistributions of any form whatsoever must retain the following acknowledgment: "This *          product includes Hypersonic SQL."  * This software is provided "as is" and any expressed or implied warranties, including, but * not limited to, the implied warranties of merchantability and fitness for a particular purpose are * disclaimed. In no event shall the Hypersonic SQL Group or its contributors be liable for any * direct, indirect, incidental, special, exemplary, or consequential damages (including, but * not limited to, procurement of substitute goods or services; loss of use, data, or profits; * or business interruption). However caused any on any theory of liability, whether in contract, * strict liability, or tort (including negligence or otherwise) arising in any way out of the use of this * software, even if advised of the possibility of such damage.  * This software consists of voluntary contributions made by many individuals on behalf of the * Hypersonic SQL Group. * * * For work added by the HSQL Development Group: * * Copyright (c) 2001-2002, The HSQL Development Group * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer, including earlier * license statements (above) and comply with all above license conditions. * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution, including earlier * license statements (above) and comply with all above license conditions. * * Neither the name of the HSQL Development Group nor the names of its * contributors may be used to endorse or promote products derived from this * software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG,  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */package org.hsqldb;import org.hsqldb.lib.ArrayUtil;import java.sql.SQLException;// fredt@users 20020225 - patch 1.7.0 by boucherb@users - named constraints// fredt@users 20020320 - doc 1.7.0 - update// tony_lai@users 20020820 - patch 595156 by tlai@users -  violation of Integrity constraint name/** *  Implementation of a table constraint with references to the indexes used *  by the constraint. * * @version    1.7.0 */class Constraint {    static final int       FOREIGN_KEY = 0,                           MAIN        = 1,                           UNIQUE      = 2;    private ConstraintCore core;    private HsqlName       constName;    private int            iType;    /**     *  Constructor declaration     *     * @param  name     * @param  t     * @param  index     */    Constraint(HsqlName name, Table t, Index index) {        core       = new ConstraintCore();        constName  = name;        iType      = UNIQUE;        core.tMain = t;        core.iMain = index;        /* fredt - in unique constraints column list for iColMain is that           of iMain        */        core.iColMain = index.getColumns();        core.iLen     = core.iColMain.length;    }    /**     *  Constructor for main constraints (foreign key references in PK table)     *     * @param  name     * @param  t     * @param  index     */    Constraint(HsqlName name, Constraint fkconstraint) {        constName = name;        iType     = MAIN;        core      = fkconstraint.core;    }    /**     *  Constructor for foreign key constraints     *     * @param  pkname     * @param  fkname     * @param  main     * @param  ref     * @param  colmain     * @param  colref     * @param  imain     * @param  iref     * @exception  SQLException  Description of the Exception     */    Constraint(HsqlName pkname, HsqlName fkname, Table main, Table ref,               int colmain[], int colref[], Index imain, Index iref,               boolean cascade) throws SQLException {        core        = new ConstraintCore();        core.pkName = pkname;        core.fkName = fkname;        constName   = fkname;        iType       = FOREIGN_KEY;        core.tMain  = main;        core.tRef   = ref;        /* fredt - in FK constraints column lists for iColMain and iColRef have           identical sets to visible columns of iMain and iRef respectively           but the order of columns can be different and must be maintained        */        core.iColMain = colmain;        core.iLen     = core.iColMain.length;        core.iColRef  = colref;        core.oColRef  = new Object[core.iColRef.length];        core.iMain    = imain;        core.iRef     = iref;        core.bCascade = cascade;        setTableRows();    }    private Constraint() {}    private void setTableRows() throws SQLException {        core.oMain = core.tMain.getNewRow();        if (core.tRef != null) {            core.oRef = core.tRef.getNewRow();        }        if (Trace.DOASSERT) {            Trace.doAssert(core.iColMain.length == core.iColRef.length);        }    }    HsqlName getName() {        return constName;    }    /**     * Changes constraint name.     *     * @param name     * @param isquoted     */    private void setName(String name, boolean isquoted) {        constName.rename(name, isquoted);    }    /**     *  probably a misnomer, but DatabaseMetaData.getCrossReference specifies     *  it this way (I suppose because most FKs are declared against the PK of     *  another table)     *     *  @return name of the index refereneced by a foreign key     */    String getPkName() {        return core.pkName == null ? null                                   : core.pkName.name;    }    /**     *  probably a misnomer, but DatabaseMetaData.getCrossReference specifies     *  it this way (I suppose because most FKs are declared against the PK of     *  another table)     *     *  @return name of the index for the referencing foreign key     */    String getFkName() {        return core.fkName == null ? null                                   : core.fkName.name;    }    /**     *  Method declaration     *     * @return name of the index for the foreign key column (child)     */    int getType() {        return iType;    }    /**     *  Method declaration     *     * @return     */    Table getMain() {        return core.tMain;    }    Index getMainIndex() {        return core.iMain;    }    /**     *  Method declaration     *     * @return     */    Table getRef() {        return core.tRef;    }    Index getRefIndex() {        return core.iRef;    }    /**     *  Does (foreign key) constraint cascade on delete     *     * @return     */    boolean isCascade() {        return core.bCascade;    }    /**     *  Method declaration     *     * @return

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -