> 文档中心 > SpringDataSolr操作Solr(一)

SpringDataSolr操作Solr(一)


1、内容如下:

  • Sorl基本增删查
  • 从数据库导入到Solr

在这里就不阐述如何安装Solr以及中文分词器

2、为了方便后续的讲述这里先贴出Solr域内容:

<field name="id" type="long" indexed="true" stored="true"/><field name="item_title" type="text_ik" indexed="true" stored="true"/><field name="item_price" type="double" indexed="true" stored="true"/><field name="item_image" type="string" indexed="false" stored="true" /><field name="item_category" type="string" indexed="true" stored="true" /><field name="item_keywords" type="text_ik" indexed="true" stored="false" multiValued="true"/><copyField source="item_title" dest="item_keywords"/><copyField source="item_category" dest="item_keywords"/>

3、配置pojo

public class TbItem implements 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_category")    private String category;/*注意:属性使用@Field注解标识 。   如果属性与配置文件定义的域名称不一致,需要在注解中指定域名称。*/}

3、引入pom文件

<dependency>    <groupId>org.springframework.data</groupId>    <artifactId>spring-data-solr</artifactId>    <version>1.5.5.RELEASE</version></dependency>

4、Sorl配置文件

<solr:solr-server id="solrServer" url="http://127.0.0.1:8080/solr" /><bean id="solrTemplate" class="org.springframework.data.solr.core.SolrTemplate"><constructor-arg ref="solrServer" /></bean>

5、‘单个’、‘批量’、'数据库’添加到Solr库

@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations="classpath:applicationContext-solr.xml")public class TestTemplate {@Autowiredprivate SolrTemplate solrTemplate;//单个添加@Testpublic void testAdd(){TbItem item=new TbItem();item.setId(123L);item.setCategory("手机");item.setTitle("这里是solr手机");item.setPrice(new BigDecimal(2000));solrTemplate.saveBean(item);solrTemplate.commit();}//批量@Testpublic void testAddList(){List<TbItem> list=new ArrayList();for(int i=0;i<100;i++){TbItem item=new TbItem();item.setId(i+1L);item.setCategory("手机");item.setTitle("这里是solr手机"+i);item.setPrice(new BigDecimal(2000+i));list.add(item);}//数据库导入到solr@Testpublic void importItemData(){//先从数据库查询List<TbItem> itemList = itemMapper.selectByExample();System.out.println("===商品列表===");for(TbItem item:itemList){System.out.println(item.getTitle());}//插入solr中solrTemplate.saveBeans(itemList);solrTemplate.commit();System.out.println("===结束===");}}

6、删除Solr

@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations="classpath:applicationContext-solr.xml")public class TestTemplate {@Autowiredprivate SolrTemplate solrTemplate;//按主键删除@Testpublic void testDelete(){solrTemplate.deleteById("1");solrTemplate.commit();}//删除所有@Testpublic void testDeleteAll(){Query query=new SimpleQuery("*:*");solrTemplate.delete(query);solrTemplate.commit();}}

7、查询操作

@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations="classpath:applicationContext-solr.xml")public class TestTemplate {//按主键查询@Testpublic void testFindOne(){TbItem item = solrTemplate.getById(1, TbItem.class);System.out.println(item.getTitle());}//分页查询@Testpublic void testPageQuery(){Query query=new SimpleQuery("*:*");query.setOffset(0);//开始索引(默认0)query.setRows(20);//每页记录数(默认10)ScoredPage<TbItem> page = solrTemplate.queryForPage(query, TbItem.class);System.out.println("总记录数:"+page.getTotalElements());//获取查询内容List<TbItem> list = page.getContent();//循环显示for(TbItem item:list){System.out.println(item.getTitle() +item.getPrice());}}//条件查询@Testpublic void testPageQueryMutil(){Query query=new SimpleQuery("*:*");Criteria criteria=new Criteria("item_title").contains("2");criteria=criteria.and("item_title").contains("5");query.addCriteria(criteria);ScoredPage<TbItem> page = solrTemplate.queryForPage(query, TbItem.class);List<TbItem> list = page.getContent();//循环显示for(TbItem item:list){System.out.println(item.getTitle() +item.getPrice());}}//条件查询可以和分页查询相结合}

上述只是说了SpringDataSolr的简单运用,其他知识需要自行掌握,代码可能无法直接运行,需要根据项目进行相应的一些调整。