SolrAdmin.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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.slf4j.Logger;
  11. import org.slf4j.LoggerFactory;
  12. import org.springframework.beans.factory.annotation.Autowired;
  13. import org.springframework.beans.factory.config.ConfigurableBeanFactory;
  14. import org.springframework.context.annotation.Scope;
  15. import org.springframework.stereotype.Service;
  16. import java.util.ArrayList;
  17. import java.util.HashMap;
  18. import java.util.List;
  19. import java.util.Map;
  20. /**
  21. * Solr底层操作类
  22. *
  23. * @author hzp
  24. * @version 1.0
  25. * @created 2017.05.06
  26. */
  27. @Service
  28. @Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)
  29. public class SolrAdmin {
  30. private static final Logger logger = LoggerFactory.getLogger(SolrAdmin.class);
  31. @Autowired
  32. private SolrPool pool;
  33. /**
  34. * 新建单条索引
  35. */
  36. public Boolean create(String core,Map<String, Object> map) throws Exception {
  37. SolrClient client = pool.getConnection(core);
  38. SolrInputDocument doc = new SolrInputDocument();
  39. //注意date的格式,要进行适当的转化
  40. for(String key:map.keySet()) {
  41. doc.addField(key, map.get(key));
  42. }
  43. UpdateResponse re = client.add(doc);
  44. client.commit();
  45. if (re.getStatus() != 0) {
  46. logger.info("create index cost " + re.getQTime());
  47. return true;
  48. } else{
  49. logger.warn("create index failed!");
  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 HashMap();
  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. List<SolrInputDocument> solrList = new ArrayList<>();
  70. for(int i = 0; i < docs.size(); i++) {
  71. SolrDocument doc = docs.get(i);
  72. SolrInputDocument newItem = new SolrInputDocument();
  73. newItem.addField("rowkey",doc.get("rowkey"));
  74. for(String key :map.keySet()) {
  75. newItem.addField(key,map.get(key));
  76. }
  77. solrList.add(newItem);
  78. }
  79. UpdateResponse re = client.add(solrList);
  80. client.commit();
  81. if(re.getStatus() != 0) {
  82. logger.info("update index cost " + re.getQTime());
  83. return true;
  84. } else{
  85. logger.warn("update index failed!");
  86. return false;
  87. }
  88. } else{
  89. logger.warn("Null result!");
  90. }
  91. return true;
  92. }
  93. /**
  94. * 删除单条索引
  95. */
  96. public Boolean delete(String core,String keyQuery) throws Exception {
  97. SolrClient client = pool.getConnection(core);
  98. UpdateResponse de = client.deleteByQuery(keyQuery);
  99. client.commit();
  100. if (de.getStatus() != 0) {
  101. logger.info("delete index cost " + de.getQTime());
  102. return true;
  103. } else{
  104. logger.warn("delete index failed!");
  105. return false;
  106. }
  107. }
  108. }