SolrAdmin.java 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package com.yihu.base;
  2. import org.apache.commons.collections.map.HashedMap;
  3. import org.apache.solr.client.solrj.SolrClient;
  4. import org.apache.solr.client.solrj.SolrQuery;
  5. import org.apache.solr.client.solrj.response.QueryResponse;
  6. import org.apache.solr.client.solrj.response.UpdateResponse;
  7. import org.apache.solr.common.SolrDocument;
  8. import org.apache.solr.common.SolrDocumentList;
  9. import org.apache.solr.common.SolrInputDocument;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.beans.factory.config.ConfigurableBeanFactory;
  12. import org.springframework.context.annotation.Scope;
  13. import org.springframework.stereotype.Service;
  14. import java.util.ArrayList;
  15. import java.util.List;
  16. import java.util.Map;
  17. /**
  18. * Solr底层操作类
  19. *
  20. * @author hzp
  21. * @version 1.0
  22. * @created 2017.05.06
  23. */
  24. @Service
  25. @Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
  26. public class SolrAdmin {
  27. @Autowired
  28. SolrPool pool;
  29. /************************* 基础操作 **************************************************/
  30. /**
  31. * 新建单条索引
  32. */
  33. public Boolean create(String core,Map<String, Object> map) throws Exception {
  34. SolrClient client = pool.getConnection(core);
  35. SolrInputDocument doc = new SolrInputDocument();
  36. //注意date的格式,要进行适当的转化
  37. for(String key:map.keySet())
  38. {
  39. doc.addField(key, map.get(key));
  40. }
  41. UpdateResponse re = client.add(doc);
  42. client.commit();
  43. pool.close(core); //释放连接
  44. if(re.getStatus()!=0) {
  45. System.out.print("create index cost " + re.getQTime());
  46. return true;
  47. }
  48. else{
  49. System.out.print("create index faild!");
  50. return false;
  51. }
  52. }
  53. /**
  54. * 修改单条索引单字段
  55. */
  56. public Boolean update(String core,String uniqueKey,String uniqueKeyValue,String key,Object value) throws Exception {
  57. Map<String,Object> map = new HashedMap();
  58. map.put(key,value);
  59. return update(core,uniqueKey+":"+uniqueKeyValue,map);
  60. }
  61. /**
  62. * 修改索引多字段
  63. */
  64. public Boolean update(String core,String keyQuery,Map<String, Object> map) throws Exception {
  65. SolrClient client = pool.getConnection(core);
  66. QueryResponse qr = client.query(new SolrQuery(keyQuery));
  67. SolrDocumentList docs = qr.getResults();
  68. if(docs!=null && docs.size()>0)
  69. {
  70. List<SolrInputDocument> solrList = new ArrayList<>();
  71. for(int i=0;i<docs.size();i++)
  72. {
  73. SolrDocument doc = docs.get(i);
  74. SolrInputDocument newItem = new SolrInputDocument();
  75. newItem.addField("rowkey",doc.get("rowkey"));
  76. for(String key :map.keySet())
  77. {
  78. newItem.addField(key,map.get(key));
  79. }
  80. solrList.add(newItem);
  81. }
  82. UpdateResponse re = client.add(solrList);
  83. client.commit();
  84. pool.close(core); //释放连接
  85. if(re.getStatus()!=0) {
  86. System.out.print("update index cost " + re.getQTime());
  87. return true;
  88. }
  89. else{
  90. System.out.print("update index faild!");
  91. return false;
  92. }
  93. }
  94. else{
  95. System.out.print("Null result!");
  96. }
  97. return true;
  98. }
  99. /**
  100. * 删除单条索引
  101. */
  102. public Boolean delete(String core,String keyQuery) throws Exception {
  103. SolrClient client = pool.getConnection(core);
  104. UpdateResponse de = client.deleteByQuery(keyQuery);
  105. client.commit();
  106. pool.close(core); //释放连接
  107. if(de.getStatus()!=0) {
  108. System.out.print("delete index cost " + de.getQTime());
  109. return true;
  110. }
  111. else{
  112. System.out.print("delete index faild!");
  113. return false;
  114. }
  115. }
  116. }