mysql导入数据到solr的方法


本文主要给大家介绍mysql导入数据到solr的方法,其所涉及的东西,从理论知识来获悉,有很多书籍、文献可供大家参考,从现实意义来讲,开发云累计多年的实践经验可分享给大家。方式一:创建项目,查询出数据,一条一条addsolr中;(不推荐)方式二:通过配置复制数据到solr以上已完成了在本地window8中对solr的部署,为solr添加了一个自定义的coredemo,并且引入了ik分词器。那么该如何将本地的mysql的数据导入到solr中呢?mysql数据源:test库中的user表(7条数据),其中这个update_time字段是用于solr更新数据库数据的依据,表中必须得有这个字段。SETFOREIGN_KEY_CHECKS=0;——————————— Table structurefor user——————————DROP TABLE IFEXISTS `user`;CREATE TABLE`user` ( `id` int(10) NOT NULL AUTO_INCREMENT, `name` varchar(30) DEFAULT NULL, `sex` int(1) DEFAULT NULL, `title` varchar(200) DEFAULT NULL, `insert_time` datetime DEFAULT NULL, `update_time` datetime DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDBAUTO_INCREMENT=8 DEFAULT CHARSET=utf8;——————————— Records of user——————开发云主机域名————INSERT INTO `user`VALUES (‘1’, ‘航三‘, ‘1’, ‘有电脑‘,’2017-05-02 15:40:19’, ‘2017-05-03 15:40:22’);INSERT INTO `user`VALUES (‘2’, ‘理三‘, ‘1’, ‘有电脑,生活就是游戏么。要努力啊‘, ‘2017-05-02 15:40:19’, ‘2017-05-03 15:40:22’);INSERT INTO `user`VALUES (‘3’, ‘李四‘, ‘0’, ‘准备工作完成之后就可以进行配置和操作了。‘, ‘2017-05-02 15:40:19’, ‘2017-05-03 15:40:22’);INSERT INTO `user`VALUES (‘4’, ‘王五‘, ‘0’, ‘这个demo主要是针对多图片上传时使用的,可以携带动态加载的参数。‘, ‘2017-05-02 15:40:19’, ‘2017-05-0315:40:22’);INSERT INTO `user`VALUES (‘5’, ‘赵六‘, ‘1’, ‘demo里也有,多文件上传+预览功能。也可以自己去调U’, ‘2017-05-25 15:43:03’, ‘2017-05-25 15:43:07’);INSERT INTO `user`VALUES (‘6’, ‘周七‘, ‘0’, ‘这个demo主要是针对多图片上传时使用的‘, ‘2017-05-02 15:43:23’, ‘2017-05-11 15:43:26’);INSERT INTO `user`VALUES (‘7’, ‘李白‘, ‘1’, ‘诗人‘,’2017-05-02 15:43:23’, ‘2017-05-02 15:43:25’);链接mysql驱动jarmysql-connector-java-5.1.14.jar(这个基本都有)D:solr-4.10.2distsolr-dataimporthandler-4.10.2.jarsolr的解压文件目录中找到“D:solr-4.10.2exampleexample-DIHsolrdbconf”下的db-data-config.xml文件到你的core(比如:D:solr-4.10.2exampledemo-solrdemoconfconf目录下,并更名为data-config.xml详细配置如下: url=”jdbc:mysql://localhost:3306/test” user=”root”password=”123456″ batchSize=”100″ /> query=”SELECTid,name,sex,title,insert_time,update_time FROM user” deltaImportQuery=”SELECTid,name,sex,title,insert_time,update_time FROM user whereid=’${dataimporter.delta.id}'” deltaQuery=”SELECT id FROMuser where update_time > ‘${dataimporter.last_index_time}'”> deltaImportQuery:获取增量数据时使用的SQL增量导入时使用deltaQuery:获取pkSQL增量导入时使用注意查询条件的写法:${..},如在本例中:${dataimporter.last_index_time}索引上次导入时间${ dataimporter.delta.id}实体user查询结果中的id,也可以用${user.id}表示关于data-config.xml详解,参考博文:http://www.jianshu.com/p/91a5a0c35475http://blog.csdn.net/boolbo/article/details/50352331注意:如果是solr是使用tomcat进行启动,只是相关的jar和配置文件放的位置不一样。配置是一致的。1、 拷贝mysql-connector-java-5.1.14.jarsolr-dataimporthandler-4.10.2.jarsolrD:solr-4.10.2examplesolr-webappwebappWEB-INFlib目录中;2,在D:solr-4.10.2exampledemo-solrdemoconf目录下,更改solrconfig.xml配置文件。添加如下内容: data-config.xml 3,在D:solr-4.10.2exampledemo-solrdemoconf目录下,更改schema.xml配置,配置相关字段: id 4,重启solr应用,查看原有的数据:还是原来的那些数据。5,导入mysql数据到solr中:选择Dataimport进行导入操作。查询:证明数据已经导入,并删除了原来的数据!Documents运行/update,指定typexml。先查询后删除:语句为:*:*Submit,执行删除!当然,上面说的是手动删除,如果要删除的数据很多,想在下一次自动同步数据的时候自动删除指定的数据该如何做呢?场景:有一批要拍卖的店铺数据存储在solr中,拍卖的店铺数据有一个拍卖结束时间(endTime),当拍卖结束时间一到,这条存储在solr中的拍卖数据就没有意义了,想要删除这条存储在solr中的数据。按照上面的手动删除也不是不可以,但这人工操作未免太扯了,到时间人工去solr中删除这条数据耗时又耗力,也不太现实。解决办法就是:data-config.xmlentity中添加:deletedPkQuery=”selectidfromshopswhereendTime<NOW()”这一句,这句和entiyquery同级,目的是查询出所有店铺数据中结束时间小于当前时间的店铺id,这个店铺id会和deltaQuery中收集到的id一并执行deltaImportQuery操作,只不过一个是添加数据,一个是删除数据。注意:这个配置在导入数据成功后,无效果。只在导入过程中有效果!1、 将所有只用于搜索的,而不需要作为结果的field(特别是一些比较大的field)的stored设置为false2、 将不需要被用于搜索的,而只是作为结果返回的fieldindexed设置为false3、 删除所有不必要的copyField声明为了索引字段的最小化和搜索的效率;4、 将所有的 text fieldsindex都设置成false,然后使用copyField将他们都复制到一个总的 text field上,然后进行搜索。看了以上介绍mysql导入数据到solr的方法,希望能给大家在实际运用中带来一定的帮助。本文由于篇幅有限,难免会有不足和需要补充的地方,大家可以继续关注开发云行业资讯板块,会定期给大家更新行业新闻和知识,如有需要更加专业的解答,可在官网联系我们的24小时售前售后,随时帮您解答问题的。

相关推荐: 数据库之锁模块

MyISAM与InnoDB关于锁方面的区别:注:实际上在不走索引的时候,InnoDB的实现方式和MyIsam的表锁方式不同,单条索引记录上加锁,record lock锁住的永远是索引,而非记录本身,即使该表上没有任何索引,那么innodb会在后台创建一个隐藏的…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/07 15:29
下一篇 06/07 15:30

相关推荐