/*
This file belongs to the Servoy development and deployment environment, Copyright (C) 1997-2010 Servoy BV
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU Affero General Public License as published by the Free
Software Foundation; either version 3 of the License, or (at your option) any
later version.
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 GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along
with this program; if not, see http://www.gnu.org/licenses or write to the Free
Software Foundation,Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
*/
package com.servoy.j2db.dataprocessing;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import com.servoy.j2db.persistence.IServer;
import com.servoy.j2db.persistence.RepositoryException;
import com.servoy.j2db.persistence.Table;
/**
* A special interface for Oracle to update binary or character large fields in the database.
* This is needed because {@link PreparedStatement#setBytes(int, byte[])} doesn't work correctly for data larger then 2K
*
* @author jcompagner
*/
public interface IOracleLobHandler
{
public void updateOracleClob(IServer server, Connection connection, Table table, String column, Object[] pk, String clob) throws RepositoryException,
SQLException, IOException;
public void updateOracleBlob(IServer server, Connection connection, Table table, String column, Object[] pk, byte[] blob) throws RepositoryException,
SQLException, IOException;
}