Resolve this Issue:
- Use ojdbc6 version 11 (http://www.oracle.com/technetwork/database/enterprise-edition/jdbc-faq-090281.html#08_01)
- CustomDateTimeUserType class defined to set the date time as java.sql.Date object to map with DB Data column.
User defined hibernate date type
import java.io.Serializable; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Timestamp; import java.sql.Types; import java.util.Date; import org.hibernate.HibernateException; import org.hibernate.usertype.UserType; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class CustomDateTimeUserType implements UserType { private final Logger logger = LoggerFactory.getLogger(this.getClass()); @Override public int[] sqlTypes() { return new int[] { Types.TIMESTAMP }; } @SuppressWarnings("rawtypes") @Override public Class returnedClass() { return Date.class; } @Override public boolean equals(Object x, Object y) throws HibernateException { return x == y || !(x == null || y == null) && x.equals(y); } @Override public int hashCode(Object x) throws HibernateException { assert (x != null); return x.hashCode(); } @Override public Object nullSafeGet(ResultSet rs, String[] names, Object owner) throws HibernateException, SQLException { Timestamp timestamp = rs.getTimestamp(names[0]); if (rs.wasNull()) { return null; } return new Date(timestamp.getTime()); } @Override public void nullSafeSet(PreparedStatement st, Object value, int index) throws HibernateException, SQLException { // if (value == null) { // st.setNull(index, Types.TIMESTAMP); // // } // else { // Date date = (Date) value; // Timestamp timestamp = new Timestamp(date.getTime()); // st.setTimestamp(index, timestamp); // } if (value == null) { st.setNull(index, Types.DATE); } else { Date date = (Date) value; Timestamp timestamp = new Timestamp(date.getTime()); st.setTimestamp(index, timestamp); // st.setDate(index, new java.sql.Date(date.getTime())); st.setObject(index, timestamp, java.sql.Types.DATE); } } @Override public Object deepCopy(Object value) throws HibernateException { return value; } @Override public boolean isMutable() { return false; } @Override public Serializable disassemble(Object value) throws HibernateException { return (Serializable) value; } @Override public Object assemble(Serializable cached, Object owner) throws HibernateException { return cached; } @Override public Object replace(Object original, Object target, Object owner) throws HibernateException { return original; } }
References:
- Non-negligible execution plan difference with Oracle when using jdbc Timestamp or Date
- Why is Oracle so slow when I pass a java.sql.Timestamp for a DATE column?
- What is going on with DATE and TIMESTAMP?
- What the heck is the INTERNAL_FUNCTION in execution plan predicate section?
- INTERNAL_FUNCTION() Impact
No comments:
Post a Comment