一、通过Java访问Solr服务(手动创建索引库)

1、创建项目,配置环境(导包及相关文件)

1、SolrJ核心包 /solr-4.10.3/dist/solr-solrj-4.10.3.jar

2、SolrJ依赖包 /solr-4.10.3/dist/solrj-lib下的所有包

3、日志依赖包 /solr-4.10.3/example/lib/ext目录下的所有jar包

4、JDBC驱动包 mysql-connector-java-5.1.10-bin.jar

5、拷贝log4j.properties到src目录下。(或者创建一个Source Folder)

项目结构如下所示

2、编写代码

【1】采集数据

1】创建pojo,创建Product类

package cn.jinshan.pojo;

public class Product {

private Integer pid;

private String name;

private String catalogName;

private double price;

private String description;

private String picture;

// 补全get、set方法}

【2】创建连接数据的 ProductDao类

package cn.jinshan.dao;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.ArrayList;

import java.util.List;

import cn.jinshan.pojo.Product;

public class ProductDao {

public List getAllProducts() {

List products = new ArrayList<>();

//连接数据库 Connection connection = null;

PreparedStatement prepareStatement=null;

ResultSet resultSet = null;

try {

//加载驱动 Class.forName("com.mysql.jdbc.Driver");

//获取连接 connection = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/solr", "root", "gzsxt");

//获取预处理编译对象 prepareStatement = connection.prepareStatement("select pid,name,price,description,catalog_name,picture from products");

//执行 resultSet = prepareStatement.executeQuery();

Product product = null;

while (resultSet.next()) {

product = new Product();

product.setPid(resultSet.getInt("pid"));

product.setName(resultSet.getString("name"));

product.setPrice(resultSet.getDouble("price"));

product.setDescription(resultSet.getString("description"));

product.setCatalogName(resultSet.getString("catalog_name"));

product.setPicture(resultSet.getString("picture"));

products.add(product);

}

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

}finally {

if (resultSet !=null) {

try {

resultSet.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if (prepareStatement != null) {

try {

prepareStatement.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

if (connection !=null) {

try {

connection.close();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

return products;

}

}

【3】创建一个测试类,测试能否取出数据

package cn.jinshan.test;

import org.junit.Test;

import cn.jinshan.dao.ProductDao;

public class ProductDaoTest {

@Test

public void getAll() {

ProductDao dao = new ProductDao();

System.out.println(dao.getAllProducts());

}

}

注:运行测试类,控制台可以打印出数据,则证明数据采集正常

【2】将数据转换成Solr文档SolrInputDocument

1】将文档的域配置在Solr实例的schema.xml配置文件中,如下图所示:

2】通过代码将数据转为SolrInputDocument文档

//将采集的数据转为SolrInputDocument文档 public List getSolrDocument(List products) {

List solrInputDocuments = new ArrayList<>();

SolrInputDocument solrInputDocument = null;

for (Product product : products) {

solrInputDocument = new SolrInputDocument();

//此处addField的域,必须跟实例的schema.xml配置文件中配置的域相同 solrInputDocument.addField("id", product.getPid());

solrInputDocument.addField("product_name", product.getName());

solrInputDocument.addField("product_catalog_name", product.getCatalogName());

solrInputDocument.addField("product_price", product.getPrice());

solrInputDocument.addField("product_description", product.getDescription());

solrInputDocument.addField("product_picture", product.getPicture());

solrInputDocuments.add(solrInputDocument);

}

return solrInputDocuments;

}

3】手动创建索引库(执行方法后,课查看实例中是否生成数据(位置:D:\java\solr\solrHome\collection1\data\index))

//手动创建索引库 @Test

public void createIndex() {

ProductDao productDao = new ProductDao();

//将数据加入到Solr的索引库 //第一步:连接Solr HttpSolrServer solrServer = new HttpSolrServer("http://localhost:8888/solr/solr1");

try {

solrServer.add(productDao.getSolrDocument(productDao.getAllProducts()));

solrServer.commit();

} catch (SolrServerException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

三、Solr服务插件及其他配置(通过配置文件系统自动创建索引)

可以在管理界面直接从数据库导入数据到索引库,不需要通过手动创建索引的全部操作

1、安装DataImport插件

【1】配置依赖包

将/solr-4.10.3/dist/solr-dataimporthandler-4.10.3.jar拷贝到/depJar/contrib/dataimporthandler/lib目录下

将jdbc驱动包拷贝到 /depJar/contrib/db/lib 目录下

【2】 加载依赖包的相关配置

在相关实例的solrconfig.xml文件中,加载这两个jar依赖,如下所示:

2、配置 数据库表和solr域的映射关系

【1】创建配置文件

在solr实例的conf目录下,配置数据库映射文件data-config.xml(建议不要修改配置文件名字),文件内容如下:

为数据库连接的相关配置

...数据库表和solr域的关联相关配置(column为表的字段,name为solr域的名称)

driver="com.mysql.jdbc.Driver"

url="jdbc:mysql://localhost:3306/solr"

user="root"

password="gzsxt"/>

配置完成,重启solr服务;

访问solr服务控制台如下,则插件安装完成

2、配置中文分析器 ( IKAnalyzer)

【1】 把IKAnalyzer2012FF_u1.jar添加到solr/WEB-INF/lib目录下

【2】 拷贝IkAnalyzer的配置文件IKAnalyzer.cfg.xml到solr/WEB-INF/classes目录下

IK Analyzer 扩展配置

stopword.dic;

【3】 在schema.xml中自定义一个FieldType,指定中文分词器IKAnalyzer

注:指定中文分词器后,solr域中的个别域的类型就不能写text_general就需要改成text_ik

java solr_通过Java访问Solr服务实例及相关配置相关推荐

  1. JavaScript脚本访问后台服务实例

    js访问后台服务实例 前端代码: function GetHeatMapFunc() {         var s_time = "2017-11-12";         va ...

  2. 【学习笔记】Eureka服务治理代码实例、相关配置和原理机制详解

    文章目录 代码示例 启动一个服务注册中心 注册服务提供者 高可用注册中心 服务的发现与消费 Eureka的一些配置 服务注册类配置 服务实例类配置 实例名配置 端点配置 Eureka服务治理基础架构原 ...

  3. 使用java的milo框架访问OPCUA服务的方法

    最近接了一个项目,需要访问工业的实时数据库,数据库的对外开放接口是OPCUA协议的,经过多方比对,发现github上milo的评星较高,尝试了一下,还比较方便好用,现在把使用过程中的坑和大家介绍一下, ...

  4. java接口允许ajax访问_服务允许AJAX请求,允许跨域请求

    当工作时间,因为需要JS 进行AJAX请求,这时候存在跨域问题,当出现这种情况时,有多种方案解决比如使用JSONP,也有一种简单的方式,就是在过滤器里面增加返回请求允许跨域head配置. 代码如下: ...

  5. java实现ip能访问_Java过滤ip,只允许配置的ip能够被访问

    Java过滤ip,只允许配置的ip能够被访问 第一先创建过滤类 实现Filter就会有init(),doFilter(),destroy()三个方法 private String ips; publi ...

  6. idea tomcat启动成功但是访问方面都是404_IDEA相关配置【集成Tomcatamp;项目部署】...

    "知其然知其所以然"始终是Brick我学习新兴技术的出发点,那么咱们来聊聊以下几个问题 问题1:在编写完web项目之后,我们怎么才能运行项目呢? --需要部署项目到Tomcat上. ...

  7. java jolt tuxedo_Java中使用Jolt访问Tuxedo服务 – Tomcat环境部署测试

    Java中使用Jolt访问Tuxedo服务 – Tomcat环境部署测试 Java中使用Jolt访问Tuxedo服务 – Tomcat环境部署测试 最近在学习基于Tuxedo的系统架构,网上讨论最多的 ...

  8. tomcat 部署 RESTful 服务实例

    1.建立简单restfule服务 参考:java 利用JAX-RS快速开发RESTful 服务实例 简单代码: package com.example;import javax.ws.rs.GET; ...

  9. SpringCloud微服务架构,Config 分布式配置中心,Bus 消息总线, Stream 消息驱动,Sleuth+Zipkin 链路追踪

    Config分布式配置中心 Config 概述 概述 • Spring Cloud Config 解决了在分布式场景下多环境配置文件的管理和维护. • 好处: • 集中管理配置文件 • 不同环境不同配 ...

最新文章

  1. 叙述无保密机制的rsa签名过程_安全系列之——RSA的公钥私钥有多少人能分的清楚?RSA的签名验签与加密解密如何使用公私钥?...
  2. 为什么 Python 3 把 print 改为函数?
  3. jupyter notebook bp网络_全华班再次败北,TES奇葩BP背大锅!签来风哥能拯救滔搏吗?...
  4. redis大幅性能提升之使用管道(PipeLine)和批量(Batch)操作
  5. EasyUi – 1.入门
  6. 以太坊POA共识机制Clique源码分析
  7. ElementUI:使input自动聚焦的两种方法
  8. “宽带中国、智慧岳阳”项目启动
  9. 初赛知识点汇总(阶段性完结
  10. MPI + OpenMP实现快速排序
  11. python激光扫描雷达_一文详解固态激光雷达的里程计(loam_livox)
  12. 使用云服务器上线网站流程
  13. mysql 派生表 索引_MySQL 索引初探
  14. 汽车多媒体主机接口EMC设计
  15. 1024程序员节活动勋章获取方式
  16. 【车牌识别】模板匹配新能源车牌识别【含Matlab源码 865期】
  17. mysql-administrator的安装与使用(图文)
  18. Win11U盘不显示怎么办?Win11插U盘没反应的解决方法
  19. Java中的集合---------Collections 类---集合的工具类 Comparator比较器
  20. 名悦集团:4S店汽车保养有哪些需避开的小雷区

热门文章

  1. 前端学习(499):水平居中布局得第一种方式得优点和缺点
  2. mybatis学习(38):动态sql-foreach
  3. 高可用的 MFS 文件分布式系统(Drdb+heartbeat+MFS )
  4. 简单总结 2019 展望 2020
  5. collection集合 多少钱_Java集合框架大汇总,建议收藏
  6. 必须进行支持的游戏方可使用此功能_C#8.0 新增功能
  7. Dubbo中的监控和管理
  8. 2.【sheel学习】数组
  9. adb命令检测apk启动时间、内存、CPU使用情况、流量、电池电量等——常用的adb命令...
  10. 《掌握需求过程》阅读笔记05