Solr 创建core 从MySql数据库中导入数据
一、创建数据表和数据
在MySql数据中创建mysolrInfo表,
创建字段
id 主键,自动增加
pname :姓名
age :年龄
addtime :增加时间

增加几条数据

二、创建core
当Solr的服务器在独立模式下启动的配置称为核心,当它在SolrCloud模式启动的配置称为集合。
方式一、命令
首先启动solr: solr start
创建core: solr create -c myfirst
如下图:

用命令导入索引数据
把目录下D:\work\Solr\solr-6.6.0\example\exampledocs的xml数据 导入
输入:java -Dauto=yes -Dc=myfirst -jar post.jar ..\example\exampledocs\*.xml

方式2、用管理界面
首先进入到solr_home文件夹(D:\work\Solr\solr_home),创建一个文件夹(first_core)用于存放新建的core, 然后进入到solr-6.6.0\server\solr\configsets\sample_techproducts_configs路径下,
将conf文件夹拷贝到刚刚创建first_core文件夹中

启动tomcat运行solr,浏览器中输入http://127.0.0.1:8080/solr/index.html,点击左侧的Core Admin -> Add Core
在name和instanceDire下都输入刚刚创建的名称: first_core,其余值默认即可,点击Add Core即可创建成功


三、修改相关配置文件
1、配置solrconfig.xml
solrconfig.xml文件与managed-shema文件是经常要修改的文件。位于创建的core目录里面的conf文件夹里。如下图:

在solrconfig.xml文件的后面配置如下信息:
<!--引入DataImportHandler类的jar-->
<requestHandler name="/dataimport" class="org.apache.solr.handler.dataimport.DataImportHandler">
<lst name="defaults">
<str name="config">data-config.xml</str>
</lst>
</requestHandler>
注意:需要确认文件中不存在其他的dataimport,如果存在直接替换即可
2、配置data-config.xml
在同级目录下创建data-config.xml文件,然后配置数据库相关属性
<?xml version="1.0" encoding="UTF-8"?>
<dataConfig>
<dataSource type="JdbcDataSource" driver="com.mysql.jdbc.Driver" url="jdbc:mysql://127.0.0.1:3306/solr_db" user="root" password="shaoks" batchSize="-1" />
<document>
<entity name="mycore_test" query="select id ,pname,age,addtime from mysolrInfo">
<!--column的id是数据库的id,name的id是managed_schema里面的id,id是必须,并且唯一的-->
<field column="id" name="id" />
<!--column的pname是数据库的pname字段,age是managed_schema里面的age,下面配置同理-->
<field column="pname" name="name" />
<field column="age" name="age" />
<field column="addtime" name="addtime" />
</entity>
</document>
</dataConfig>
3,配置managed-schema.xml
下面的字段要和上面的data-config.xml里面字段对应起来
<schema name="example" version="1.6">
。。。
<field name="id" type="int" indexed="true" stored="false"/>
<field name="pname" type="string" indexed="true" stored="true"/>
<field name="age" type="string" indexed="true" stored="true"/>
<field name="addtime" type="date" indexed="true" stored="true"/>
<uniqueKey>id</uniqueKey>
</schema>
网上很多教程说到schema.xml,这个文件是solr之前的版本中用到的,6.6版本是不需要的,直接修改上面的文件就可以。

4,拷贝jar
拷贝solr-6.6.0\dist路径下的solr-dataimporthandler-6.6.0.jar,solr-dataimporthandler-extras-6.6.0.jar 到D:\work\tomcat\apache-tomcat-9.0.0.M26\webapps\solr\WEB-INF\lib目录下
同时拷贝mysql-connector-java-5.1.6-bin.jar链接jar到该目录下 mysql-connector-java-5.1.6-bin.jar可从网上下载:http://www.java2s.com/Code/Jar/m/Downloadmysqlconnectorjava516binjar.htm

下载解压后拷贝到指定路径
不需要修改任何配置文件即可,继续下面的步骤
5、重启tomcat
在浏览器运行 http://127.0.0.1:8080/solr/index.html

执行导入

查询

导入成功
Solr 创建core 从MySql数据库中导入数据的更多相关文章
- Solr 07 - Solr从MySQL数据库中导入数据 (Solr DIH的使用示例)
目录 1 加入数据导入处理器的jar包 2 加入数据库驱动包 3 配置solrconfig.xml文件 3.1 配置lib标签 - 加入驱动jar包 3.2 配置requestHandler标签 - ...
- solr6.6教程-从mysql数据库中导入数据(三)
整理多半天的solr6.6,终于算是把solr6.6中配置数据库弄出来了,网上的文章千篇一律,各说个的,没有一篇统一覆盖solr6.6版本配置的 帖子,本章节我会把配置的一些注意事项一一列举,由于时间 ...
- [MySQL]load data local infile向MySQL数据库中导入数据时,无法导入和字段不分离问题。
利用load data将文件中的数据导入数据库表中的时候,遇到了两个问题. 首先是load data命令无法执行的问题: 命令行下输入load data local infile "path ...
- 使用sqoop将MySQL数据库中的数据导入Hbase
使用sqoop将MySQL数据库中的数据导入Hbase 前提:安装好 sqoop.hbase. 下载jbdc驱动:mysql-connector-java-5.1.10.jar 将 mysql-con ...
- 从Mysql数据库中导入导出表结构
1.从Mysql数据库中导入sql表 很简单,只需要一个命令即可搞定:[root@localhost ~]# mysql -uroot -piweb_xxx_mysql iweb < modif ...
- python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图
python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图 # coding=utf-8 from openpyxl import load_workbook ...
- JDBC Java 程序从 MySQL 数据库中读取数据,并备份到 xml 文档中
MySQL 版本:Server version: 5.7.17-log MySQL Community Server (GPL) 相关内容:JDBC Java 程序从 MySQL 数据库中读取数据,并 ...
- 使用grabit分析mysql数据库中的数据血缘关系
使用grabit分析mysql数据库中的数据血缘关系 Grabit 是一个辅助工具,用于从数据库.GitHub 等修订系统.bitbucket 和文件系统等各种来源收集 SQL 脚本和存储过程,然后将 ...
- mysql数据库中插入数据INSERT INTO SET的优势
往mysql数据库中插入数据.以前常用 INSERT INTO 表名 (列名1,列名2…) VALUES(列值1,列值2); 如果在PHP程序中,就会写成如下示例(往商品库里增加商品) $sql = ...
随机推荐
- [C语言]防止头文件和全局变量重复定义
昨天下午将全局变量定义在H文件中导致链接时提示变量在多个obj文件内重复. 解决办法如下: 将变量移入C文件中进行定义,然后在H文件中加入extern在变量之前. 这样当其它C文件引用该全局变量时 ...
- HDU 6165 FFF at Valentine(Tarjan缩点+拓扑排序)
FFF at Valentine Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- [洛谷P2216][HAOI2007]理想的正方形
题目大意:有一个$a\times b$的矩阵,求一个$n\times n$的矩阵,使该区域中的极差最小. 题解:二维$ST$表,每一个点试一下是不是左上角就行了 卡点:1.用了一份考试时候写的二维$S ...
- vue(三)
一.vue的特点 1.响应式的数据绑定(一旦修改了数据,立马更新视图) 数据驱动思想 (数据到视图的映射.操作数据改变视图.简化对DOM的操作) 追踪依赖变化 ( Object.defineProp ...
- XmlSerializer使用
XmlSerializer是对xml进行序列化操作的对象.写了一个Order的序列化方法供留念. 序列化针对有get,set的属性:属性必须是public方式:对象顺序和序列化的顺序一致. 对象定义 ...
- 51Nod 1558 树中的配对
题目链接 分析: 想了好久~~~还是得看题解...QwQ 首先因为是排列,所以我们猜想要把式子拆开来看, $ \sum dis(i,p[i])=\sum dep[i]+dep[p[i]]-2*dep[ ...
- poj1039 Pipe(计算几何叉积求交点)
F - Pipe Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit Sta ...
- Zabbix监控服务器异常IP登录
保存下面的脚本到任意路径 名字.py 修改属组和权限: chown zabbix:zabbix * chmod 755 * 演示的路径为:/usr/local/zabbix/scripts/ # -* ...
- 使用两个 Windows 窗体 DataGridView 控件创建一个主/从窗体
使用 DataGridView 控件的一种最常见方案是“主/详细信息”窗体,这样的窗体可显示两个数据库表之间的父/子关系.如果选择主表中的行,将导致以相应的子数据来更新详细信息表. 主/详细信息窗体很 ...
- iOS手势UIGestureRecognizer的使用失效问题
问题:视图正常展示在界面中,父层是放在window上的,底部的一个控件的点击事件失效(所有设置都正常) 解决思路:虽然视图能够正常展示,但是发现父类视图的底部尺寸比子类的视图的尺寸小,也就是说上层视图 ...