: A type that maps an SQL TIMESTAMP to a Java
java.util.Date or java.sql.Timestamp.
| Method from org.hibernate.type.TimestampType Detail: |
public Object deepCopyNotNull(Object value) {
if ( value instanceof Timestamp ) {
Timestamp orig = (Timestamp) value;
Timestamp ts = new Timestamp( orig.getTime() );
ts.setNanos( orig.getNanos() );
return ts;
}
else {
java.util.Date orig = (java.util.Date) value;
return new java.util.Date( orig.getTime() );
}
}
|
public Object fromStringValue(String xml) throws HibernateException {
try {
return new Timestamp( new SimpleDateFormat(TIMESTAMP_FORMAT).parse(xml).getTime() );
}
catch (ParseException pe) {
throw new HibernateException("could not parse XML", pe);
}
}
|
public Object get(ResultSet rs,
String name) throws SQLException {
return rs.getTimestamp(name);
}
|
public Comparator getComparator() {
return ComparableComparator.INSTANCE;
}
|
public int getHashCode(Object x,
EntityMode entityMode) {
java.util.Date ts = (java.util.Date) x;
return new Long( ts.getTime() / 1000 ).hashCode();
}
|
public String getName() {
return "timestamp";
}
|
public Class getReturnedClass() {
return java.util.Date.class;
}
|
public boolean isEqual(Object x,
Object y) {
if (x==y) return true;
if (x==null || y==null) return false;
long xTime = ( (java.util.Date) x ).getTime();
long yTime = ( (java.util.Date) y ).getTime();
boolean xts = x instanceof Timestamp;
boolean yts = y instanceof Timestamp;
int xNanos = xts ? ( (Timestamp) x ).getNanos() : 0;
int yNanos = yts ? ( (Timestamp) y ).getNanos() : 0;
if ( !Environment.jvmHasJDK14Timestamp() ) {
xTime += xNanos / 1000000;
yTime += yNanos / 1000000;
}
if ( xTime!=yTime ) return false;
if (xts && yts) {
// both are Timestamps
int xn = xNanos % 1000000;
int yn = yNanos % 1000000;
return xn==yn;
}
else {
// at least one is a plain old Date
return true;
}
}
|
public Object next(Object current,
SessionImplementor session) {
return seed( session );
}
|
public String objectToSQLString(Object value,
Dialect dialect) throws Exception {
return '\'" + new Timestamp( ( (java.util.Date) value ).getTime() ).toString() + '\'";
}
|
public Object seed(SessionImplementor session) {
return new Timestamp( System.currentTimeMillis() );
}
|
public void set(PreparedStatement st,
Object value,
int index) throws SQLException {
Timestamp ts;
if (value instanceof Timestamp) {
ts = (Timestamp) value;
}
else {
ts = new Timestamp( ( (java.util.Date) value ).getTime() );
}
st.setTimestamp(index, ts);
}
|
public int sqlType() {
return Types.TIMESTAMP;
}
|
public String toString(Object val) {
return new SimpleDateFormat(TIMESTAMP_FORMAT).format( (java.util.Date) val );
}
|