org.firebirdsql.jdbc.field.FBFlushableField Maven / Gradle / Ivy
/*
* Firebird Open Source JavaEE Connector - JDBC Driver
*
* Distributable under LGPL license.
* You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* LGPL License for more details.
*
* This file was created by members of the firebird development team.
* All individual contributions remain the Copyright (C) of those
* individuals. Contributors to this file are either listed here or
* can be obtained from a source control history command.
*
* All rights reserved.
*/
package org.firebirdsql.jdbc.field;
import java.io.InputStream;
import java.io.Reader;
import java.sql.SQLException;
/**
* Instances of this field cache data in auto-commit case if no transaction is
* yet available and must be flushed before transaction is committed.
*
* @author Roman Rokytskyy
* @version 1.0
*/
public interface FBFlushableField {
class CachedObject {
public byte[] bytes;
public InputStream binaryStream;
public Reader characterStream;
public long length;
public CachedObject(byte[] bytes, InputStream binaryStream, Reader characterStream, long length) {
this.bytes = bytes;
this.binaryStream = binaryStream;
this.characterStream = characterStream;
this.length = length;
}
}
/**
* Flush cached data to the database server.
*
* @throws SQLException
* if something went wrong.
*/
void flushCachedData() throws SQLException;
/**
* Get cached data.
*
* @return cached object of this field.
* @throws SQLException
* if something went wrong.
*/
byte[] getCachedData() throws SQLException;
CachedObject getCachedObject() throws SQLException;
void setCachedObject(CachedObject cachedObject) throws SQLException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy