在項目中使用Solr

web.xmlhtml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">

  <!-- 加載spring容器 -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath*:spring/applicationContext*.xml</param-value>
  </context-param>
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
</web-app>

2個配置文件(在resources下的spring文件夾下)java

applicationContext-service.xmlweb

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd
        http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
 
    <dubbo:protocol name="dubbo" port="20884"></dubbo:protocol>
    <dubbo:application name="pinyougou-search-service"/>  
    <dubbo:registry address="zookeeper://192.168.200.128:2181"/>
    <dubbo:annotation package="cn.wangju.core.service" />
</beans>

applicationContext-solr.xmlspring

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:solr="http://www.springframework.org/schema/data/solr" xsi:schemaLocation="http://www.springframework.org/schema/data/solr 
http://www.springframework.org/schema/data/solr/spring-solr-1.0.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context.xsd">
     
    <!-- solr服務器地址 -->
    <solr:solr-server id="solrServer" url="http://192.168.200.128:8080/solr" />
    <!-- solr模板,使用solr模板可對索引庫進行CRUD的操做 -->
    <bean id="solrTemplate" class="org.springframework.data.solr.core.SolrTemplate">
        <constructor-arg ref="solrServer" />
    </bean>
</beans>

業務邏輯層的實現類spring-mvc

package cn.wangju.core.service;
/**
 * @author wangju
 * @date 2019/11/21 19:20
 */
@Service
public class SearchItemServiceImpl implements SearchItemService{
    @Autowired
    private SolrTemplate solrTemplate;

    @Override
    public Map<String, Object> searchItem(Map searchMap) {
        // 獲取查詢的條件
        String keywords = (String)searchMap.get("keywords");
        //當前頁
        Integer pageNo = (Integer) searchMap.get("pageNo");
        //每頁查詢多少條
        Integer pageSize = (Integer) searchMap.get("pageSize");

        // 封裝查詢對象
        Query query = new SimpleQuery();
        Criteria criteria = new Criteria("item_keywords").is(keywords);
        //將查詢的條件放入查詢的對象
        query.addCriteria(criteria);
        if (pageNo!=null || pageNo<0){
            pageNo = 1;
        }
        pageNo = (pageNo-1)*pageSize;
        // 設置第幾條開始
        query.setOffset(pageNo);
        // 每頁查詢多少條數據
        query.setRows(pageSize);
        // 去solr 查詢並返回結果
        ScoredPage<Item> items = solrTemplate.queryForPage(query, Item.class);
        Map<String,Object> map = new HashMap<>();
        map.put("rows",items.getContent());
        map.put("totalPages",items.getTotalPages());
        map.put("total",items.getTotalElements());
        return map;
    }
}
相關文章
相關標籤/搜索