1.已安装solr-7.2.1
安装参考
已安装maven、jdk等,myeclipse配置好二者环境。
2.创建maven项目
file—new—maven project(勾选Create a simple project和Use default Workspace location)—next—输入Group Id和Artifact Id—finish
3.配置build path:jdk1.8、maven dependencies、Referenced Libraries(导入了安装目录solr-7.2.1\server\solr-webapp\webapp\WEB-INF\lib和solr-7.2.1\dist中的jar包)
4.代码
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com</groupId>
<artifactId>SolrTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
</dependencies>
<build />
</project>
Product.java
package how2java;
import org.apache.solr.client.solrj.beans.Field;
public class Product {
@Field
String id;
@Field
String name;
@Field
String category;
@Field
float price;
@Field
String place;
@Field
String code;
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 getCategory() {
return category;
}
public void setCategory(String category) {
this.category = category;
}
public float getPrice() {
return price;
}
public void setPrice(float price) {
this.price = price;
}
public String getPlace() {
return place;
}
public void setPlace(String place) {
this.place = place;
}
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
@Override
public String toString() {
return "Product [id=" + id + ", name=" + name + ", category=" + category + ", price=" + price + ", place="
+ place + ", code=" + code + "]";
}
}
SolrDemo.java
package how2java;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrClient;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.SolrInputDocument;
public class SolrDemo {
// 指定solr服务器的地址
private final static String SOLR_URL = "http://localhost:8983/solr/how2java";
// 创建一个客户端
public static HttpSolrClient createSolrServer() {
HttpSolrClient solrServer = null;
solrServer = new HttpSolrClient.Builder(SOLR_URL).withConnectionTimeout(10000).withSocketTimeout(60000).build();
return solrServer;
}
// 添加文档
public static void addDoc() throws SolrServerException, IOException {
// 构造一篇文档
SolrInputDocument document = new SolrInputDocument();
// 往doc中添加字段,在客户端这边添加的字段必须在服务端中有过定义
document.addField("id", "157940");
document.addField("name", "这是添加测试");
document.addField("category", "美妆会场");
document.addField("price",200);
document.addField("place", "上海");
document.addField("code", "10000000000");
HttpSolrClient solrServer = createSolrServer();
solrServer.add(document);
solrServer.commit();
System.out.println("成功插入数据");
solrServer.close();
}
// 删除Solr中新建立的索引 没有更改
public static void deleteDocById() throws Exception { // 选择具体的某一个solr core
HttpSolrClient solrServer = createSolrServer();
solrServer.deleteById("157940");
// solr.deleteByQuery("*:*"); // 删除所有的索引
// 提交修改
solrServer.commit();
solrServer.close();
}
// 查询
public static List<Product> querySolr() throws Exception {
HttpSolrClient solrServer = createSolrServer();
SolrQuery query = new SolrQuery();// 创建并设置关键词过滤条件
query.set("q", "code:10000000000");
//SolrQuery solrQuery = new SolrQuery("id:10014");
QueryResponse queryResponse = solrServer.query(query); //创建QueryResponse数据接收对象
List<Product> resultlist = queryResponse.getBeans(Product.class);
// solrQuery.setSort("id", SolrQuery.ORDER.desc); // 设置排序
// solrQuery.setStart(0); // 设置分页开始记录数
// solrQuery.setRows(3); // 设置查询条数
//System.out.print(resultlist);
return resultlist;
}
public static void main(String[] args) throws Exception {
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
String startTime = df.format(new Date());// newDate()为获取当前系统时间,也可使用当前时间戳
//插入
addDoc();
//删除
//deleteDocById();
String endTime = df.format(new Date());
//查询
List<Product> reslist = new ArrayList<Product>();
reslist = querySolr();
if (reslist != null && reslist.size() > 0) {
for (Product product : reslist) {
System.out.println("name:" + product.getName());
}
}
//System.out.print(reslist);
//String endTime = df.format(new Date());
Date d1 = df.parse(startTime);
Date d2 = df.parse(endTime);
System.out.print("-----solr实时查询耗时" + (d2.getTime() - d1.getTime()) + "毫秒-----");
}
/*最初主函数,只实现查询
public static void main(String[] args) {
// 1、定义配置好的solr访问路径
String url = "http://localhost:8983/solr/how2java";
// 创建一个客户端
HttpSolrClient solr = null;
solr = new HttpSolrClient.Builder(url).withConnectionTimeout(10000).withSocketTimeout(60000).build();
// 2、初始化HttpSolrClient
// HttpSolrClient httpSolrClient = new HttpSolrClient(url);
solr.setParser(new XMLResponseParser()); // 设置响应解析器
// httpSolrClient.setConnectionTimeout(500); // 设置建立连接的最长时间
// 3、初始化SolrQuery
SolrQuery solrQuery = new SolrQuery("id:10014"); // 创建并设置关键词过滤条件
// solrQuery.setSort("id", SolrQuery.ORDER.desc); // 设置排序
// solrQuery.setStart(0); // 设置分页开始记录数
// solrQuery.setRows(3); // 设置查询条数
// 4、创建QueryResponse数据接收对象
// QueryResponse queryResponse = null; // 定义接受句柄
try {
QueryResponse queryResponse = solr.query(solrQuery);
List<Product> productList = queryResponse.getBeans(Product.class);
// 另外一种写法
// List<Product> productList = new ArrayList<Product>();
// SolrDocumentList list = queryResponse.getResults();
// DocumentObjectBinder binder = new DocumentObjectBinder();
// productList = binder.getBeans(Product.class, list);
if (productList != null && productList.size() > 0) {
for (Product product : productList) {
System.out.println("name:" + product.getName());
}
}
} catch (SolrServerException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
*/
}
运行:右键SolrDemo.java->Run as->Java Application
注意:
Product.java中参数类型要与solr管理页面中的数据类型一致
因为使用@field注解
否则可能报java.lang.IllegalArgumentException错误