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

一、通过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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/417847.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WCF RIA优缺点

优点&#xff1a;WCF RIA提供方便的数据访问形式&#xff0c;服务端代码写在.cs文件中继承DomainService&#xff0c;类前要声明[EnableClientAccess()]生成后sliverlight项目中/Generated_Code下会有对应的.g.cs文件&#xff0c;该文件会包含WCF RIA服务中各方法的访问方法。缺…

SpringMVC+MyBatis 返回时间格式转换的解决方案

Spring MVC 4.X ResponseBody 日期类型Json 处理 摘自http://tramp-zzy.iteye.com/blog/2090330 2014-07-10方法一&#xff1a;全局处理 <mvc:annotation-driven> <!-- 处理responseBody 里面日期类型 --> <mvc:message-converters> …

SqlServer Split功能函数

CREATE FUNCTION [dbo].[StrSplit](str nvarchar(max), --源字符串split varchar(32) --分隔符)RETURNS t TABLE(col nvarchar(max))AS BEGINWHILE(charindex(split,str)<>0) BEGININSERT t(col) VALUES(substring(str,1,charindex(split,str)-1))SET str stuff(s…

java 内存堆和栈_java堆内存和栈内存的处理

前段时间学习二叉树在处理删除操作的时候遇到一个头疼的问题&#xff1a;删除节点的时候明明已经置null了可树上该节点依旧存在&#xff0c;还必须执行node.father.left null;才可以删除node节点&#xff0c;寻找了一下原因发现还是因为对java内存管理理解不够深入。代码如下&…

maven编译项目时提示:cached in the local repository

1.今天使用命令mvn compile编译maven项目时提示错误信息&#xff0c;部分错误信息如下&#xff1a; Failure to transfer wsdl4j:wsdl4j:jar:1.6.3 from http://xx.xx.xx.xx:8081/nexus/content/groups/public was cached in the local repository, resolution will not be re…

MS SQLSERVER中如何快速获取表的记录总数

&#xff08;转自&#xff1a;http://www.cnblogs.com/pingkeke/archive/2006/05/29/411995.html&#xff09;在数据库应用的设计中&#xff0c;我们往往会需要获取某些表的记录总数&#xff0c;用于判断表的记录总数是否过大&#xff0c;是否需要备份数据等。我们通常的做法是…

java 压缩指定文件_Java将指定文件/文件夹压缩成zip、rar压缩文件

import org.apache.tools.zip.ZipEntry;import org.apache.tools.zip.ZipOutputStream;import java.io.*;import java.util.zip.CheckedOutputStream;import java.util.zip.CRC32;/*** author chenssy** 将指定文件/文件夹压缩成zip、rar压缩文件*/public class ZipCompressor …

python基础(十三)

项目实战&#xff1a;运维堡垒机开发 前景介绍 到目前为止&#xff0c;很多公司对堡垒机依然不太感冒&#xff0c;其实是没有充分认识到堡垒机的IT管理中的重要作用的&#xff0c;很多人觉得&#xff0c;堡垒机就是跳板机&#xff0c;其实这个认识是不全面的&#xff0c;跳板功…

使用 TABLESAMPLE 限制结果集

TABLESAMPLE 子句将从 FROM 子句中的表返回的行数限制到样本数或行数的某一百分比。例如&#xff1a; 复制代码 TABLESAMPLE (10 PERCENT) /*Return a sample 10 percent of the rows of the result set. */TABLESAMPLE (15 ROWS) /* Return a sample of 15 rows from the resu…

Catalan数(数论)

Catalan数 【参考网址】http://www.cnblogs.com/gongxijun/p/3232682.html 记得当时我们队写过一个&#xff0c;差点超时&#xff0c;现在找到了公式&#xff0c;感觉还是挺简单的。 还要注意&#xff0c;就算开long long 也只能表示到第33个&#xff0c;之后就会溢出。 &…

C#参考资料

C#参考资料 C# 读写XML文件 xmlDocumentC#时间函数c#读写XML文件在C#中使用异步Socket编程实现TCP网络服务的CS的通...C# socket传文件c#调用API要点

java面向_java是面向什么的语言?

Java是一门面向对象编程语言&#xff0c;不仅吸收了C语言的各种优点&#xff0c;还摒弃了C里难以理解的多继承、指针等概念&#xff0c;因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表&#xff0c;极好地实现了面向对象理论&#xff0c;…

RAISERROR (Transact-SQL)

来源&#xff1a; SQL Server 2005 联机丛书 生成错误消息并启动会话的错误处理。RAISERROR 可以引用 sys.messages 目录视图中存储的用户定义消息&#xff0c;也可以动态建立消息。该消息作为服务器错误消息返回到调用应用程序&#xff0c;或返回到 TRY…CATCH 构造的关联 CAT…

使用awk取passwd10-20行然后重定向

1、先找到要做实验的文件cp。 cp /etc/passwd /tmp/xusx 2、使用awk取passwd10-20的第三列从定向输出test.txt 第一步 awk NR>10 && NR<20 /tmp/xusx/passwd >>/tmp/xusx/test.txt 第二步 rootlocalhost xusx]# awk NR>10 && NR<20 /tmp/x…

jsp mysql做登入界面_用jsp实现网站登录界面的制作,并连接数据库

这里介绍一下怎样连接数据库&#xff0c;并用jsp制作一个简单的登录界面1.首先需要搭建好环境&#xff0c;有Tomcat&#xff0c;eslipse,jdk等&#xff0c;并配置好环境变量&#xff0c;并安装好数据库&#xff0c;这里我使用的数据库是mysql数据库&#xff0c;并下载了一个MyS…

decimal 和 numeric (Transact-SQL)

带固定精度和小数位数的数值数据类型。 decimal[ (p[ , s] )] 和 numeric[ (p[ , s] )] 固定精度和小数位数。使用最大精度时&#xff0c;有效值从 - 10^38 1 到 10^38 - 1。decimal 的 SQL-92 同义词为 dec 和 dec(p, s)。numeric 在功能上等价于 decimal。p&#xff08;精度…

java流的应用_Java中I/O流的应用

Java中I/O流的应用iLeGeNDpackagecom.hp.io;/** I/O流的应用 * 实现目标&#xff1a; * 首先创建一个文件 * 通过键盘向文件添加内容 * 然后把文件的内容打印到控制台 * */import java.io.BufferedReader;import java.io.File;import java.io.FileInputStream;import ja…

PHP的反射类ReflectionClass、ReflectionMethod使用实例

PHP5 具有完整的反射API&#xff0c;添加对类、接口、函数、方法和扩展进行反向工程的能力。 反射是什么&#xff1f; 它是指在PHP运行状态中&#xff0c;扩展分析PHP程序&#xff0c;导出或提取出关于类、方法、属性、参数等的详细信息&#xff0c;包括注释。这种动态获取的信…

java 多线程跑数据_java——多线程的实现方式、三种办法解决线程赛跑、多线程数据同步(synchronized)、死锁...

多线程的实现方式&#xff1a;demo1、demo2demo1&#xff1a;继承Thread类&#xff0c;重写run()方法packagethread_test;public class ThreadDemo1 extendsThread {ThreadDemo1(){}ThreadDemo1(String szName){super(szName);}//重载run函数public voidrun() {for(int count …