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

📄 scriptreaderbinary.java

📁 hsqldb是100%java实现的数据库,是一个开放源代码的JAVA数据库 l 具有标准的SQL语法和JAVA接口 l HSQLDB可以自由使用和分发 l 非常简洁和快速的
💻 JAVA
字号:
/* Copyright (c) 2001-2005, 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. * * 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. * * 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.scriptio;import java.io.BufferedInputStream;import java.io.DataInputStream;import java.io.EOFException;import java.io.IOException;import java.io.InputStream;import org.hsqldb.Database;import org.hsqldb.HsqlException;import org.hsqldb.Result;import org.hsqldb.ResultConstants;import org.hsqldb.Session;import org.hsqldb.Table;import org.hsqldb.Trace;import org.hsqldb.lib.Iterator;import org.hsqldb.lib.SimpleLog;import org.hsqldb.rowio.RowInputBase;import org.hsqldb.rowio.RowInputBinary;/** * Reader corresponding to BinaryDatabaseScritReader. * * @author fredt@users * @version 1.7.2 * @since 1.7.2 */class ScriptReaderBinary extends ScriptReaderBase {    private RowInputBinary    rowIn;    protected DataInputStream dataStreamIn;    ScriptReaderBinary(Database db,                       String file) throws HsqlException, IOException {        super(db, file);        rowIn = new RowInputBinary();    }    protected void openFile() throws IOException {        InputStream d = db.isFilesInJar()                        ? getClass().getResourceAsStream(fileName)                        : db.getFileAccess().openInputStreamElement(fileName);        dataStreamIn = new DataInputStream(new BufferedInputStream(d,                1 << 13));    }    protected void readDDL(Session session)    throws IOException, HsqlException {        Result   r  = Result.read(rowIn, dataStreamIn);        Iterator it = r.iterator();        while (it.hasNext()) {            Object[] data   = (Object[]) it.next();            String   s      = (String) data[0];            Result   result = session.sqlExecuteDirectNoPreChecks(s);            if (result.isError()) {                db.logger.appLog.logContext(SimpleLog.LOG_ERROR,                                            result.getMainString());                /** @todo fredt - trap if unavaialble external functions are to be ignored */                throw Trace.error(result);            }        }    }    protected void readExistingData(Session session)    throws IOException, HsqlException {        for (;;) {            String s = readTableInit();            if (s == null) {                break;            }            String schema = session.getSchemaName(currentSchema);            Table  t      = db.schemaManager.getUserTable(session, s, schema);            int    j      = 0;            for (j = 0; ; j++) {                if (readRow(t) == false) {                    break;                }            }            int checkCount = readTableTerm();            if (j != checkCount) {                throw Trace.error(Trace.ERROR_IN_SCRIPT_FILE,                                  Trace.ERROR_IN_BINARY_SCRIPT_1,                                  new Object[] {                    s, new Integer(j), new Integer(checkCount)                });            }        }    }    // int : row size (0 if no more rows) ,    // BinaryServerRowInput : row (column values)    protected boolean readRow(Table t) throws IOException, HsqlException {        boolean more = readRow(rowIn, 0);        if (!more) {            return false;        }        Object[] data = rowIn.readData(t.getColumnTypes());        t.insertFromScript(data);        return true;    }    // int : rowcount    protected int readTableTerm() throws IOException, HsqlException {        return dataStreamIn.readInt();    }    // int : headersize (0 if no more tables), String : tablename, int : operation,    // String : schemaname    protected String readTableInit() throws IOException, HsqlException {        boolean more = readRow(rowIn, 0);        if (!more) {            return null;        }        String s = rowIn.readString();        // operation is always INSERT        int checkOp = rowIn.readIntData();        if (checkOp == ScriptWriterBase.INSERT_WITH_SCHEMA) {            currentSchema = rowIn.readString();        } else {            currentSchema = null;        }        if (checkOp != ScriptWriterBase.INSERT                && checkOp != ScriptWriterBase.INSERT_WITH_SCHEMA) {            throw Trace.error(Trace.ERROR_IN_SCRIPT_FILE,                              Trace.ERROR_IN_BINARY_SCRIPT_2);        }        return s;    }    boolean readRow(RowInputBase rowin, int pos) throws IOException {        try {            int length = dataStreamIn.readInt();            int count  = 4;            if (length == 0) {                return false;            }            rowin.resetRow(pos, length);            dataStreamIn.readFully(rowin.getBuffer(), count, length - count);            return true;        } catch (EOFException e) {            return false;        }    }    public boolean readLoggedStatement(Session session) throws IOException {        return false;    }    public void close() {        try {            dataStreamIn.close();        } catch (IOException e) {}    }}

⌨️ 快捷键说明

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