Solr对数据库中的CLOB字段建立索引

对于oracl中的clob字段,solr建立索引时,如果没有作处理,否则会展示成这样。

<content>oracle.sql.CLOB@1723c20</content>


需要在db-data-config.xml中加入如下红色的部分:

transformer="ClobTransformer"

<field column="CONTENT" name="content" clob="true" />

[html]  view plain  copy
  1. <dataConfig>  
  2.     <dataSource type="JdbcDataSource" name="jdbc" driver="oracle.jdbc.driver.OracleDriver"  
  3.               url="jdbc:oracle:thin:@//*.*.*.*:port/orcl" user="root" password="root"/>  
  4.     <document>  
  5.         <entity name="item" transformer="ClobTransformer" query="select ID as id,NAME as name,PRICE as price,  
  6.                              SUMMARY as summary,CONTENT as content from BOOK"  
  7.             <field column="CONTENT" name="content" clob="true" />  
  8.         </entity>  
  9.     </document>  
  10. </dataConfig>  


这个field的column一定要写成大写的CONTENT,要不然转换不了。

在schema.xml中添加需要检索的field

[html]  view plain  copy
  1. <fields>  
  2.         <field name="id" type="string" indexed="true" stored="true" required="true" />  
  3.         <field name="name" type="textMaxWord_cn" indexed="true" stored="true" />  
  4.         <field name="price" type="long" indexed="true" stored="true" />  
  5.         <field name="summary" type="textMaxWord_cn" indexed="true" stored="true" />  
  6.         <field name="content" type="textMaxWord_cn" indexed="true" stored="true" />  
  7.         <field name="searchText" type="textMaxWord_cn" indexed="true" stored="false" multiValued="true" />  
  8.  </fields>  
  9.   
  10.  <uniqueKey>id</uniqueKey>  
  11.  <defaultSearchField>searchText</defaultSearchField>  
  12.  <solrQueryParser defaultOperator="AND" />  
  13.  <copyField source="name" dest="searchText" />  
  14.  <copyField source="summary" dest="searchText" />  
  15.  <copyField source="content" dest="searchText" />  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值