/**
* Copyright (C) 2010 Orbeon, Inc.
*
* This program is free software; you can redistribute it and/or modify it under the terms of the
* GNU Lesser General Public License as published by the Free Software Foundation; either version
* 2.1 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 Lesser General Public License for more details.
*
* The full text of the license is available at http://www.gnu.org/copyleft/lesser.html
*/
package org.orbeon.oxf.processor.sql.delegates;
import org.orbeon.oxf.common.OXFException;
import org.orbeon.oxf.processor.sql.DatabaseDelegate;
import org.w3c.dom.Node;
import java.io.ByteArrayOutputStream;
import java.io.OutputStream;
import java.io.StringReader;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
/**
* Custom Delegate that uses the standard JDBC API which works fine with MySQL and DB2.
*/
public class SQLProcessorStandardDelegate implements DatabaseDelegate {
public OutputStream getBlobOutputStream(final PreparedStatement stmt, final int index) throws SQLException {
return new ByteArrayOutputStream() {
public void close() {
try {
stmt.setBytes(index, toByteArray());
} catch (SQLException e) {
throw new OXFException(e);
}
}
};
}
public void setBlob(PreparedStatement stmt, int index, byte[] value) throws SQLException {
stmt.setBytes(index,value);
}
public void setClob(PreparedStatement stmt, int index, String value) throws SQLException {
stmt.setCharacterStream(index, new StringReader(value), value.length());
}
public boolean isXMLType(int columnType, String columnTypeName) throws SQLException {
return false;
}
public Node getDOM(ResultSet resultSet, String columnName) throws SQLException {
throw new UnsupportedOperationException();
}
public void setDOM(PreparedStatement stmt, int index, String document) throws SQLException {
throw new UnsupportedOperationException();
}
}