[转自:http://hi.baidu.com/tuoxinquyu/item/e4a11af796628bb630c19954]
今天遇到oracle.sql.TIMESTAMP类型的转换问题,解决办法如下:
eg 1:
try {
Class clz =logMap.get("INPUTDATETIME").getClass();
//Methodmethod = clz.getMethod("timestampValue",null);
//method =clz.getMethod("timeValue", null); 时间类型
Method method =clz.getMethod("timestampValue", null); //日期类型
Date date = (Date) method.invoke(logMap.get("INPUTDATETIME"));
System.out.println(date);
} catch (Exception e) {
Date date = new Date();
}
logMap.get("INPUTDATETIME") 为 从数据库拿到的oracle.sql.TIMESTAMP类型的数据 .
eg 2 :
if (os[0].getClass().getName().equals("oracle.sql.TIMESTAMP")){
Class clz = os[0].getClass();
Method m = clz.getMethod("timestampValue");
java.sql.Timestamp t = (java.sql.Timestamp) m.invoke(os[0]);
System.out.println("t=" + t);
}
eg 3:
从结果集中拿出的时间类型是oracle.sql.TIMESTAMP,如果直接resultSet.getTimestamp(index)可以由resultSet类自己实现转换,但如果在resultSet里取出Object,再实行转换就无法直接与java的标准类对号入座了
利用反射解决的方法:
private Timestamp getOracleTimestamp(Object value) {
try {
Class clz =value.getClass();
Method method = clz.getMethod("timestampValue",null);
//Method method =clz.getMethod("timeValue", null); 时间类型
//Method method =clz.getMethod("dateValue", null); 日期类型
return(Timestamp) m.invoke(value, null);
} catch (Exception e) {
returnnull;
}
}