SPRINGMVC整合SOLR
-
<dependency>
-
<groupId>org.apache.solr</groupId>
-
<artifactId>solr-solrj</artifactId>
-
<version>7.0.1</version>
-
</dependency>
2、配置一个spring-solr.xml
-
-
<beans xmlns="http://www.springframework.org/schema/beans"
-
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:http="http://www.springframework.org/schema/c"
-
xsi:schemaLocation="http://www.springframework.org/schema/beans
-
http://www.springframework.org/schema/beans/spring-beans.xsd">
-
-
<bean id="httpSolrClient"
-
class="org.apache.solr.client.solrj.impl.HttpSolrClient">
-
<constructor-arg index="0" value="http://192.168.52.13:8983/solr/comInfo_core"/>
-
<!-- 建立连接的最长时间 -->
-
<!--<property name="connectionTimeout"
-
value="${solr.connectionTimeout}"/>-->
-
<property name="connectionTimeout" value="3000"/>
-
</bean>
-
-
</beans>
3、在这里我是将solr交给spring管理的,只写了service层跟serviceImpl
-
@Service
-
public class SolrImpl implements IsolrService {
-
@Autowired
-
HttpSolrClient client;
-
@Override
-
public List<CommodityInfoDto> solr(String text) throws IOException, SolrServerException {
-
-
SolrQuery query=new SolrQuery();
-
-
String queryText="infoName:"+text+"* or infoArtist:"+text+" or infoAddress:"+text+"*";
-
query.set("q",queryText);
-
//1、过滤器
-
//query.set("fq","infoPrice:[1 TO 1000]");
-
//2、排序
-
//query.set("sort","infoPrice desc","id asc");
-
//3、设置查询到的文档返回的域对象
-
query.set("fi","id,infoName,infoArtist,infoAddress");
-
-
//4、设置默认查询的域
-
query.set("df","infoName","infoArtist","infoAddress");
-
-
//5.分页
-
query.set("start",0);
-
query.set("rows",10);
-
-
//6、高亮
-
//设置高亮域(设置的域必须在查询条件中存在)
-
query.addHighlightField("infoName");
-
query.addHighlightField("infoArtist");
-
query.addHighlightField("infoAddress");
-
//前缀
-
query.setHighlightSimplePre("<em style='color:red'>");//这里的话,如果用thymeleaf模板,css样式生效需要加th:utext...
-
//后缀
-
query.setHighlightSimplePost("</em>");
-
-
QueryResponse response = client.query(query);
-
//普通查询
-
SolrDocumentList results = response.getResults();
-
List<CommodityInfoDto> comList=new ArrayList<CommodityInfoDto>();
-
//高亮查询
-
NamedList<SimpleOrderedMap> namedList= (NamedList<SimpleOrderedMap>) response.getResponse().get("highlighting");
-
//k是id,内部的map的key是域名,其value是高亮的值集合
-
/*Map<String, Map<String, List<String>>> highlighting = response.getHighlighting();*/
-
System.out.println("匹配的结果总数是-------"+results.getNumFound());
-
for(SolrDocument document:results){
-
CommodityInfoDto comInfo=new CommodityInfoDto();
-
Integer id=Integer.parseInt((String)document.get("id"));
-
comInfo.setInfoId(id);;
-
comInfo.setInfoName((String)document.get("infoName"));
-
comInfo.setInfoImg((String)document.get("infoImg"));
-
comInfo.setInfoArtist((String)document.get("infoArtist"));
-
comInfo.setInfoTime((String)document.get("infoTime"));
-
comInfo.setInfoAddress((String)document.get("infoAddress"));
-
comInfo.setInfoPrice((String)document.get("infoPrice"));
-
comInfo.setInfoTicket((String)document.get("infoTicket"));
-
for(int i=0;i<namedList.size();i++){
-
String nameId = namedList.getName(i);
-
if(id.toString().equals(nameId)){
-
SimpleOrderedMap map=namedList.getVal(i);//获取某个商品的高亮
-
//这里是需要加判断的,不然会有空值加进去
-
ArrayList infoName = (ArrayList) map.get("infoName");
-
if(infoName!=null&& infoName.size()>0){
-
String highInfoName=(String)infoName.get(0);
-
comInfo.setInfoName(highInfoName);
-
}
-
-
-
ArrayList infoArtist = (ArrayList) map.get("infoArtist");
-
if(infoArtist!=null&& infoArtist.size()>0){
-
String highinfoArtist=(String)infoArtist.get(0);
-
comInfo.setInfoArtist(highinfoArtist);
-
}
-
-
-
ArrayList infoAddress = (ArrayList) map.get("infoAddress");
-
if(infoAddress!=null&& infoAddress.size()>0){
-
String highinfoAddress=(String)infoAddress.get(0);
-
comInfo.setInfoArtist(highinfoAddress);
-
}
-
}
-
}
-
comList.add(comInfo);
-
}
-
return comList;
-
}
-
}
4、我这里是通过用户输入一个字符,里面内容包括商品名字+商品艺人姓名+商品地址,联合查询,查询出来的对象也不会是重复的数据
-
//查询商品
-
@Test
-
public void test11(){
-
try {
-
List<CommodityInfoDto> list = solr.solr("演唱");
-
for(CommodityInfoDto com:list){
-
System.out.println("-------------->"+com);
-
}
-
} catch (IOException e) {
-
e.printStackTrace();
-
} catch (SolrServerException e) {
-
e.printStackTrace();
-
}
-
}
-
}