OracleNClobDataType.java

  1. /*
  2. *
  3. * The DbUnit Database Testing Framework
  4. * Copyright (C)2002-2004, DbUnit.org
  5. *
  6. * This library is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * This library is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with this library; if not, write to the Free Software
  18. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  19. *
  20. */
  21. package org.dbunit.ext.oracle;

  22. import oracle.jdbc.OraclePreparedStatement;

  23. import org.slf4j.Logger;
  24. import org.slf4j.LoggerFactory;

  25. import java.sql.PreparedStatement;
  26. import java.sql.SQLException;

  27. import org.dbunit.dataset.datatype.TypeCastException;

  28. /**
  29.  * NCLOB handler
  30.  * @author cris.daniluk
  31.  * @author Last changed by: $Author$
  32.  * @version $Revision$ $Date$
  33.  * @since May 3, 2005
  34.  */
  35. public class OracleNClobDataType extends OracleClobDataType {

  36.     /**
  37.      * Logger for this class
  38.      */
  39.     private static final Logger logger = LoggerFactory.getLogger(OracleNClobDataType.class);

  40.     public void setSqlValue(Object value, int column, PreparedStatement statement)
  41.             throws SQLException, TypeCastException
  42.     {
  43.         logger.debug("setSqlValue(value={}, column={}, statement={}) - start",
  44.             value, column, statement);

  45.         OraclePreparedStatement oraclePreparedStatement = statement.unwrap(OraclePreparedStatement.class);
  46.         oraclePreparedStatement.setFormOfUse(column, OraclePreparedStatement.FORM_NCHAR);
  47.         statement.setObject(column, getClob(value, statement.getConnection()));
  48.     }

  49. }