作者:蜃海 | 来源:互联网 | 2023-07-20 11:33
首先,在maven的pom.xml文件中配置对spring和solrj客户端的依赖:<projectxmlnshttp:maven.apache.orgPOM4.0.
首先,在maven的pom.xml文件中配置对spring和solrj客户端的依赖:
4.0.0
com.itszt.DemoSS1
DemoSS1
1.0-SNAPSHOT
jar
DemoSS1
http://maven.apache.org
UTF-8
org.springframework
spring-context
4.1.3.RELEASE
org.springframework
spring-beans
4.1.3.RELEASE
org.springframework
spring-jdbc
4.1.3.RELEASE
org.springframework
spring-aspects
4.1.3.RELEASE
org.apache.solr
solr-solrj
4.10.1
junit
junit
4.12
test
org.springframework
spring-test
4.1.3.RELEASE
test
配置solr.properties文件中的solr服务器信息:
solr.Url=http://127.0.0.1:8090/solr/products2
solr.maxRetries=2
solr.cOnnectionTimeout=5000
配置spring-solr-config.xml文件中的solrj客户端信息:
配置spring-config.xml文件:
测试代码如下:
package com.itszt.DemoSS1;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.SolrDocument;
import org.apache.solr.common.SolrDocumentList;
import org.apache.solr.common.SolrInputDocument;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import java.io.IOException;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* maven整合spring与solr
*/
@ContextConfiguration(locatiOns= { "classpath:spring-config.xml" })
@RunWith(SpringJUnit4ClassRunner.class)
public class TestUpdate {
@Autowired
HttpSolrServer httpSolrServer;
@Test
public void testInsertData() throws IOException, SolrServerException {
SolrInputDocument solrInputDocument=new SolrInputDocument();
solrInputDocument.addField("id","10086");
solrInputDocument.addField("product_price","998");
solrInputDocument.addField("product_name","大黄音乐");
httpSolrServer.add(solrInputDocument);
httpSolrServer.commit();
}
@Test
public void testUpdateData() throws IOException, SolrServerException {
SolrInputDocument solrInputDocument=new SolrInputDocument();
solrInputDocument.addField("id","10086");
solrInputDocument.addField("product_price","998888");
solrInputDocument.addField("product_name","大黄音乐555");
httpSolrServer.add(solrInputDocument);
httpSolrServer.commit();
}
@Test
public void testDelete() throws IOException, SolrServerException {
// httpSolrServer.deleteById("10086");
httpSolrServer.deleteByQuery("product:大黄音乐");
httpSolrServer.commit();
}
@Test
public void testQuery() throws SolrServerException {
SolrQuery solrQuery=new SolrQuery();
solrQuery.setQuery("product:挂钩");
QueryResponse queryRespOnse= httpSolrServer.query(solrQuery);
SolrDocumentList results = queryResponse.getResults();
for (SolrDocument result : results) {
Collection fieldNames = result.getFieldNames();
for (String fieldName : fieldNames) {
System.out.println(fieldName+" ----> "+result.get(fieldName));
}
}
}
@Test
public void testQuery2() throws SolrServerException { SolrQuery solrQuery=new SolrQuery();
solrQuery.setQuery("product_name:家居");
solrQuery.setFields("product_name,product_price");
solrQuery.setFilterQueries("product_price:[10 TO 100]");
solrQuery.setSort("product_price", SolrQuery.ORDER.asc);
solrQuery.setHighlight(true);
solrQuery.set("hl.fl","product_name");
QueryResponse queryRespOnse= httpSolrServer.query(solrQuery);
SolrDocumentList results = queryResponse.getResults();
System.out.println("查询回来的数量:"+results.size());
for (SolrDocument result : results) {
Collection fieldNames = result.getFieldNames();
for (String fieldName : fieldNames) {
System.out.println(fieldName+" ----> "+result.get(fieldName));
System.out.println("------------------------------------");
}
}
//获取高亮数据:
System.out.println("获取高亮数据:");
Map>> highlighting = queryResponse.getHighlighting();
Set set1 = highlighting.keySet();
for (String key1 : set1) {
System.out.println("key1---->"+key1);
Map> map2 = highlighting.get(key1);
System.out.println("map2 = " + map2);
Set set2 = map2.keySet();
for (String key2 : set2) {
System.out.println("key2---->"+key2);
}
}
}
}