继上一篇在linux环境下搭建成功solr服务器之后,本篇讲述如何在java程序中对solr进行基本的API使用和操作,
启动solr服务器后,进入solr的可视化管控台
1、新建maven工程,创建过程略过,
pom文件添加依赖的jar包
2、接下来创建两个类,一个是person的对象类,封装了和配置文件中配置的业务字段相对应的字段的一个实体对象,
public class Person {
@Field(value = "id")
private String id;
@Field(value = "name")
private String name;
@Field(value = "description")
private String description;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
}
接下来就是具体操作solr的代码,实际项目中可根据需要对操作solr的增删改查的方法做进一步的封装,新建SolrUtil工具类,
public class SolrUtil {
//solr服务器所在的地址,core0为自己创建的文档库目录
private final static String SOLR_URL = "http://192.168.111.130:8080/solr/core0";
/**
* 获取客户端的连接
*
* @return
*/
public HttpSolrClient createSolrServer() {
HttpSolrClient solr = null;
solr = new HttpSolrClient.Builder(SOLR_URL).withConnectionTimeout(10000).withSocketTimeout(60000).build();
return solr;
}
/**
* 往索引库添加文档
*
* @throws SolrServerException
* @throws IOException
*/
public void addDoc() throws SolrServerException, IOException {
SolrInputDocument document = new SolrInputDocument();
document.addField("id", "7");
document.addField("name", "钢铁侠");
document.addField("description", "一个逗比的码农");
HttpSolrClient solr = new HttpSolrClient.Builder(SOLR_URL).withConnectionTimeout(10000)
.withSocketTimeout(60000).build();
solr.add(document);
solr.commit();
solr.close();
System.out.println("添加成功");
}
/**
* 根据ID从索引库删除文档
*
* @throws SolrServerException
* @throws IOException
*/
public void deleteDocumentById() throws SolrServerException, IOException {
HttpSolrClient server = new HttpSolrClient.Builder(SOLR_URL)
.withConnectionTimeout(10000)
.withSocketTimeout(60000).build();
server.deleteById("6");
server.commit();
server.close();
}
/**
* 根据设定的查询条件进行文档字段的查询
* @throws Exception
*/
public void querySolr() throws Exception {
HttpSolrClient server = new HttpSolrClient.Builder(SOLR_URL)
.withConnectionTimeout(10000)
.withSocketTimeout(60000).build();
SolrQuery query = new SolrQuery();
//下面设置solr查询参数
//query.set("q", "*:*");// 参数q 查询所有
query.set("q", "钢铁侠");//相关查询,比如某条数据某个字段含有周、星、驰三个字 将会查询出来 ,这个作用适用于联想查询
//参数fq, 给query增加过滤查询条件
query.addFacetQuery("id:[0 TO 9]");
query.addFilterQuery("description:一个逗比的码农");
//参数df,给query设置默认搜索域,从哪个字段上查找
query.set("df", "name");
//参数sort,设置返回结果的排序规则
query.setSort("id",SolrQuery.ORDER.desc);
//设置分页参数
query.setStart(0);
query.setRows(10);
//设置高亮显示以及结果的样式
query.setHighlight(true);
query.addHighlightField("name");
query.setHighlightSimplePre("<font color='red'>");
query.setHighlightSimplePost("</font>");
//执行查询
QueryResponse response = server.query(query);
//获取返回结果
SolrDocumentList resultList = response.getResults();
for(SolrDocument document: resultList){
System.out.println("id:"+document.get("id")+" document:"+document.get("name")+" description:"+document.get("description"));
}
//获取实体对象形式
List<Person> persons = response.getBeans(Person.class);
System.out.println(persons.get(0).getName());
}
public static void main(String[] args) throws Exception {
SolrUtil solr = new SolrUtil();
//solr.addDoc();
solr.querySolr();
}
}
接下来分别测试各个方法,向core0中添加一个文件,运行结果如下,
进入管控台,查看添加的数据;
可以看到刚刚的内容已经成功添加到solr服务器中了;
直接在代码中进行查询,看是否能够搜索到刚刚添加的信息,
如果按照设置的调价没有查到结果,会抛出下面异常,
如果设置正确,则显示结果如下,返回文档的信息,
或者进行模糊匹配,查询全部的结果:
最后测试一下删除的方法,
本篇到此结束,谢谢观看!