solr导入Oracle日期时间数据的处理

参考文章:
http://stackoverflow.com/questions/10111517/getting-correct-time-from-oracle-date-in-solr-dataimporthandler

在导入Oracle数据的时候,总是只有日期,但是时间信息每个记录都是一样的,在网上查了很多资料,只有参考文章中的办法成功了

做法:在data-config.xml配置文件中加入自定义transformer处理:

<?xml version="1.0" encoding="UTF-8"?>
<dataConfig>
<script><![CDATA[
function startDateTransform(row){
// Get the timestamp and convert it to a date
var dateVal = row.get("ADD_ATT").dateValue();
// Put the correct date object into the original column
row.put("ADD_ATT", dateVal);
if(row.get("MODI_DD")!=null){
dateVal = row.get("MODI_DD").dateValue();
row.put("MODI_DD", dateVal);
}
return row;
}
]]></script>
<dataSource type="JdbcDataSource" driver="oracle.jdbc.OracleDriver"
url="jdbc:oracle:thin:@101.174.8.206:1521:orcl"
user="usr"
password="pwd"/>

<document name="gqh_position">
<entity name="gqh_position"
query="SELECT CP_ID,P_NAME,CATE_TITLE,COMPANY_NAME,DESCRIPTION,EDU_LEVEL,TITLE_LEVEL,DAN_WEI_JJ,CAST(ADD_AT AS TIMESTAMP) AS ADD_ATT,
CAST(MODI_AT AS TIMESTAMP) AS MODI_DD,SALARY FROM GQH_POSITION_FULL_VIEW"
transformer="ClobTransformer,script:startDateTransform">
<!-- ROUND(TO_NUMBER(sysdate - modi_at) * 24 * 60) -->
<field column="CP_ID" name="CP_ID" />
<field column="P_NAME" name="P_NAME" />
<field column="CATE_TITLE" name="CATE_TITLE" clob="true"/>
<field column="COMPANY_NAME" name="COMPANY_NAME" />
<field column="EDU_LEVEL" name="EDU_LEVEL" />
<field column="DAN_WEI_JJ" name="DAN_WEI_JJ" clob="true" />
<field column="ADD_ATT" name="ADD_AT"/>
<field column="MODI_DD" name="MODI_AT" />
<field column="SALARY" name="SALARY"/>
</entity>
</document>
</dataConfig>


这样在客户端取得数据显示的时候

p.setStamp((Date)doc.getFieldValue("ADD_AT")); //p是vo对象
//在jsp页面中显示
<fmt:formatDate value="${p.stamp}" pattern="yyyy-MM-dd HH:mm:ss" />


关于deltaimport的配置:

deltaImportQuery="SELECT CP_ID,P_NAME,CATE_TITLE,COMPANY_NAME,DESCRIPTION,EDU_LEVEL,TITLE_LEVEL,DAN_WEI_JJ,CAST(ADD_AT AS TIMESTAMP) AS ADD_ATT,
CAST(MODI_AT AS TIMESTAMP) AS MODI_DD,SALARY FROM GQH_POSITION_FULL_VIEW WHERE to_char(ADD_AT,'YYYY-MM-DD HH24:MI:SS') > '${dataimporter.last_index_time}'
OR to_char(MODI_AT,'YYYY-MM-DD HH24:MI:SS') > '${dataimporter.last_index_time}'"
deltaQuery="SELECT CP_ID,P_NAME,CATE_TITLE,COMPANY_NAME,DESCRIPTION,EDU_LEVEL,TITLE_LEVEL,DAN_WEI_JJ,CAST(ADD_AT AS TIMESTAMP) AS ADD_ATT,
CAST(MODI_AT AS TIMESTAMP) AS MODI_DD,SALARY FROM GQH_POSITION_FULL_VIEW WHERE to_char(ADD_AT,'YYYY-MM-DD HH24:MI:SS') > '${dataimporter.last_index_time}'
OR to_char(MODI_AT,'YYYY-MM-DD HH24:MI:SS') > '${dataimporter.last_index_time}'"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值