• Spring Data Solr入门


    1、 Spring Data Solr简介

    虽然支持任何编程语言的能力具有很大的市场价值,你可能感兴趣的问题是:我如何将Solr的应用集成到Spring中?可以,Spring Data Solr就是为了方便Solr的开发所研制的一个框架,其底层是对SolrJ(官方API)的封装。

    2、 Spring Data Solr入门小Demo

    2.1 搭建工程

    (1)创建maven工程,pom.xml中引入依赖

    <dependencies>
        <dependency>
          <groupId>org.springframework.data</groupId>
          <artifactId>spring-data-solr</artifactId>
          <version>1.5.5.RELEASE</version>
        </dependency>
    
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>4.2.4.RELEASE</version>
        </dependency>
    
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.9</version>
        </dependency>
    </dependencies>


    (2)在src/main/resources下创建  applicationContext-solr.xml

    <?xmlversion="1.0"encoding="UTF-8"?>
    
    <beansxmlns="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-serverid="solrServer"url="http://127.0.0.1:8080/solr"/>
        <!-- solr模板,使用solr模板可对索引库进行CRUD的操作 -->
        <beanid="solrTemplate"class="org.springframework.data.solr.core.SolrTemplate">
            <constructor-argref="solrServer"/>
        </bean>
    
    </beans>


    2.2 @Field 注解
     

    创建 cn.itcast.pojo 包,将品优购的TbItem实体类拷入本工程  ,属性使用@Field注解标识 。   如果属性与配置文件定义的域名称不一致,需要在注解中指定域名称。

    public class TbItemimplements Serializable{
    
        @Field
        private Long id;
    
        @Field("item_title")
        private String title;
    
        @Field("item_price")
        private BigDecimal price;
     
        @Field("item_image")
        private String image;
     
        @Field("item_goodsid")
        private Long goodsId;
     
        @Field("item_category")
        private String category;
    
        @Field("item_brand")
        private String brand;
    
        @Field("item_seller")
        private String seller;
        .......
    
    }


    2.3 增加(修改)
     

    创建测试类TestTemplate.java

    @RunWith(SpringJUnit4ClassRunner.class)
    @ContextConfiguration(locations="classpath:applicationContext-solr.xml")
    public class TestTemplate {
    @Autowired
    private SolrTemplate solrTemplate; @Test publicvoid testAdd(){ TbItem item=new TbItem(); item.setId(1L); item.setBrand("华为"); item.setCategory("手机"); item.setGoodsId(1L); item.setSeller("华为2号专卖店"); item.setTitle("华为Mate9"); item.setPrice(new BigDecimal(2000)); solrTemplate.saveBean(item); solrTemplate.commit(); } }


    2.4 按主键查询

      @Test
        public void testFindOne(){
            TbItem item = solrTemplate.getById(1, TbItem.class);
            System.out.println(item.getTitle());
    
        }


     
    2.5 按主键删除

      @Test
        public void testDelete(){
            solrTemplate.deleteById("1");
            solrTemplate.commit();
    
        }

    2.6 分页查询

    首先循环插入100条测试数据

      @Test
        public void testAddList(){
            List<TbItem>list=new ArrayList();
            for(inti=0;i<100;i++){
                TbItem item=new TbItem();
                item.setId(i+1L);
                item.setBrand("华为");
                item.setCategory("手机");
                item.setGoodsId(1L);
                item.setSeller("华为2号专卖店");
                item.setTitle("华为Mate"+i);
                item.setPrice(new BigDecimal(2000+i)); 
                list.add(item);
            }
    
    
            solrTemplate.saveBeans(list);
            solrTemplate.commit();
        }


    编写分页查询测试代码: 

        @Test
        public void testPageQuery(){
            Query query=new SimpleQuery("*:*");
            query.setOffset(20);//开始索引(默认0)
            query.setRows(20);//每页记录数(默认10)
            ScoredPage<TbItem>page = solrTemplate.queryForPage(query, TbItem.class);
            System.out.println("总记录数:"+page.getTotalElements());
            List<TbItem>list = page.getContent();
            showList(list);
        }  
    
        //显示记录数据
    
        private void showList(List<TbItem>list){    
            for(TbItem item:list){
                System.out.println(item.getTitle() +item.getPrice());
            }      
        }


    2.7 条件查询
     

    Criteria 用于对条件的封装:

      @Test
        public void testPageQueryMutil(){   
            Query query=new SimpleQuery("*:*");
            Criteria criteria=new Criteria("item_title").contains("2");
            criteria=criteria.and("item_title").contains("5");     
            query.addCriteria(criteria);
            //query.setOffset(20);//开始索引(默认0)
            //query.setRows(20);//每页记录数(默认10)
            ScoredPage<TbItem> page = solrTemplate.queryForPage(query, TbItem.class);
            System.out.println("总记录数:"+page.getTotalElements());
            List<TbItem>list = page.getContent();
            showList(list);
    
        }


    2.8 删除全部数据

    
    

       @Test

        public void testDeleteAll(){

            Query query=new SimpleQuery("*:*");

            solrTemplate.delete(query);

            solrTemplate.commit();

        }
  • 相关阅读:
    SQL: 从一个表随机读取一行或几行记录的问题
    Android: 创建一个AlertDialog对话框,必须按确定或取消按钮才能关闭对话框,禁止按[返回键]或[搜索键]关闭
    Asp: 解决脚本输出网页出现乱码情况
    Java: |(或运算) 与 多选判断
    ASP: Response 对象 错误 'ASP 0251 : 80004005' 解决办法
    Java: 在dos窗口输入密码,不要把密码直接显示出来,原来可以这么简单
    Android: 网络随时需要在3G和Wifi切换,网络程序需要注意
    Android: 待机时如何让程序继续运行 extends Service
    Android: View换切后,无法正常设置焦点或切换后TextView的虚拟键盘不弹出
    MySQL存储过程学习笔记
  • 原文地址:https://www.cnblogs.com/zeussbook/p/11200733.html
Copyright © 2020-2023  润新知