1、单机版solrj的使用:
public class SolrTest {
/**
* solr的增加或修改
* @throws IOException
*/
@Test
public void test1() throws Exception {
//创建连接
SolrServer solrService = new HttpSolrServer("http://localhost:8080/solr");
//创建solr文档对象
SolrInputDocument doc = new SolrInputDocument();
//创建域
doc.setField("id", "z001");
doc.setField("product_name", "小米手机");
doc.setField("product_price", "100");
doc.setField("product_catalog_name", "发烧的手机");
solrService.add(doc);
solrService.commit();
}
/**
* 删除数据
*/
@Test
public void test2() throws Exception {
SolrServer solrService = new HttpSolrServer("http://localhost:8080/solr");
solrService.deleteByQuery("id:z001");
solrService.commit();
}
/**
* 查询数据1
* @throws SolrServerException
*/
@Test
public void test3() throws SolrServerException {
//创建连接
SolrServer solrService = new HttpSolrServer("http://129.204.6.53:8080/solr");
//创建查询条件对象
SolrQuery solrQuery = new SolrQuery();
solrQuery.setQuery("*:*");
//查询并获取查询的相应对象
QueryResponse response = solrService.query(solrQuery);
//从响应对象中获取查询的数据信息
SolrDocumentList result = response.getResults();
//查询的条数
System.out.println("查询的条数:"+result.getNumFound());
//便利数据集
for (SolrDocument doc : result) {
System.out.println("id:"+ doc.get("id"));
System.out.println("商品名称:"+ doc.get("product_name"));
System.out.println("商品价格:"+ doc.get("product_price"));
System.out.println("商品分类名称:"+ doc.get("product_catalog_name"));
System.out.println("=============分隔符=============");
}
}
/**
* 查询数据 2
*/
@Test
public void test4() throws Exception {
//创建连接
SolrServer solrService = new HttpSolrServer("http://localhost:8080/solr");
//创建查询条件
SolrQuery query = new SolrQuery();
//设置查询条件
query.setQuery("台灯");
//设置默认搜索域
query.set("df", "product_keywords");
//根据价格设置过滤条件
query.addFilterQuery("product_price:[1 TO 100]");
//设置排序
query.setSort("product_price",ORDER.desc);
// 设置分页数据
// 开始条数
query.setStart(0);
//设置一页显示的条数
query.setRows(10);
//设置高亮信息
//高亮默认是关闭的 需要打开
query.setHighlight(true);
//设置需要高亮显示的域
query.addHighlightField("product_name");
//设置高亮的前缀
query.setHighlightSimplePre("<span style=\"color:red\">");
query.setHighlightSimplePost("</span>");
//查询之后获取响应的对象
QueryResponse response = solrService.query(query);
//根据响应的对象获取结果集
SolrDocumentList lists = response.getResults();
//打印查询数据信息
System.out.println("查询的条数:"+lists.getNumFound());
for (SolrDocument doc : lists) {
System.out.println("id:"+ doc.get("id"));
//获取高亮的信息
Map<String, Map<String, List<String>>> highlighting = response.getHighlighting();
List<String> list = highlighting.get(doc.get("id")).get("product_name");
if(list != null && list.size() > 0) {
String hlName = list.get(0);
System.out.println("高亮的商品名称:"+ hlName);
}
System.out.println("商品名称:"+ doc.get("product_name"));
System.out.println("商品价格:"+ doc.get("product_price"));
System.out.println("商品分类名称:"+ doc.get("product_catalog_name"));
System.out.println("=============分隔符=============");
}
}
2、集群版solrj的使用:
public class SolrCloudTest {
@Test
public void test1() throws SolrServerException, IOException {
//创建solr对象 后面ip地址是zookeeper集群的地址
CloudSolrServer solr = new CloudSolrServer("129.204.6.53:2181,129.204.6.53:2182,129.204.6.53:2183");
// 设备默认的collection
solr.setDefaultCollection("collection2");
//创建一个文档对象
SolrInputDocument document = new SolrInputDocument();
document.setField("id", 1);
document.setField("content", "我是中国人");
solr.add(document);
solr.commit();
}
@Test
public void test2() throws SolrServerException, IOException {
//创建solr对象 后面ip地址是zookeeper集群的地址
CloudSolrServer solr = new CloudSolrServer("129.204.6.53:2181,129.204.6.53:2182,129.204.6.53:2183");
// 设备默认的collection
solr.setDefaultCollection("collection2");
SolrQuery solrQuery = new SolrQuery();
solrQuery.setQuery("*:*");
//创建一个文档对象
//查询并获取查询的相应对象
QueryResponse response = solr.query(solrQuery);
//从响应对象中获取查询的数据信息
SolrDocumentList result = response.getResults();
//查询的条数
System.out.println("查询的条数: "+ result.getNumFound());
//便利数据集
for (SolrDocument doc : result) {
System.out.println("id:"+ doc.get("id"));
System.out.println("商品名称:"+ doc.get("content"));
}
}