lucenelucene 原理

lucene  时间:2021-08-16  阅读:()

如何用Lucene索引数据库

Lucene一个常见的用例是在一个或者多个数据库表进行全文检索。

虽然MySql有全文检索的功能,但是如果字段和数据量增加,MySql的性能会减低很快。

映射数据到Lucene 用伪代码表示: String sql = “select id, firstname, lastname, phone, email from person”; ResultSet rs = stmt.executeQuery(sql); while (rs.next()) { Document doc = new Document(); doc.add(new Field(”id”, rs,getString(”firstname”), Field.Store.YES, Field.Index.UN_TOKENIZED)); doc.add(new Field(”firstname”, rs,getString(”firstname”), Field.Store.YES, Field.Index.TOKENIZED)); // … repeat for each column in result set writer.addDocument(doc);} 显示搜索结果 当显示搜索结果给用户时,你有两个选择: 1.因为你的Table已经扁平化到了Lucene里面,所以只需要用Document里面的Field.因为Lucene也非常快,这样会大大减低你的数据库的压力。

2.如果你要显示另外的数据到你的搜索结果页,你只需要在Hits里面收集他们的ID,然后从数据库去数据再根据结果组装搜索结果页。

要搜索的东西 以上列出的方式都是假设把整个结果集放到内存里面,这样在数据集大的话会很容易造成问题,你需要在你的SQL里面做一些分页或者offset 你还需要在你的结果集里面做一个try/catch,这样当添加一个Document出错的时候不会影响整个过程。

通常情况下可以把所有的field放到同一个”Contents” field然后只搜索这一个字段,但是需要保留这些field这样可以按field检索。

如果你需要检索多个table 通常最好能用不同的索引来搜索不同类型的数据,而不是把他们加到同一个index然后根据类型来区分。

原因: 可以更简单的维护操作。

问个很菜的有关问题,lucene如何读

呵呵,小弟英语确实很差,这技术也没接触过,刚刚才看到的 我女朋友用到,我得给她讲,这东西不知道怎么读……各位帮忙------解决方案--------------------------------------------------------Lucene是一个非常优秀的开源的全文搜索引擎,我们可以在它的上面开发 出各种全文搜索的应用来。

Lucene在国外有很高的知名度,现在已经是Apache的顶级项目, 在国内,Lucene的应用也越来越多。

读法就直接照字面读就行了,因为不是一个本来就有的单词,所以只要读得不太离谱就行了 ------解决方案--------------------------------------------------------我读的是 路森呢 哈哈 ------解决方案--------------------------------------------------------建议安个金山词霸之类的,它里面有朗读功能! ------解决方案--------------------------------------------------------又长见识了------解决方案--------------------------------------------------------卢斯呢

用Lucene查询数据库,高手请进,急!!!谢谢!!!

lucene不能直接查数据库,你得把数据库的东西取出来写到索引文件里头去。

可以先把数据库里的东西写到resultset中然后在一个一个取出来写到索引里。

注意每个document里面写数据库里一行的数据,例如数据库有id和name两列,则每个document都包含一个id和一个name信息。

这样你搜“奔驰”时,才能显示所有相关信息。

具体建立索引和搜索的实现网上都有相关代码,搜一搜就可以了。

lucene 原理

public static void addIndex(java.sql.ResultSet rs) throws SQLException, CorruptIndexException, IOException{ Analyzer luceneAnalyzer = new StandardAnalyzer(); //实例化一个标准分析器 (对字符串进行索引分析的算法) 你可以把它看作一个分词器 IndexWriter indexWriter = new IndexWriter("e:/weihai/sou", luceneAnalyzer, true);//实例化一个输出流,true重新创建,false增量创建 while(rs.next()){ //java.sql.ResultSet rs 你要建立索引的对象 Document document = new Document(); // 实例化一个文档对象 这个文档可以说是保存索引内容的文档 String goods_id = rs.getString("goods_id"); //这是需要建立索引的实体对象 if(goods_id==null) goods_id=""; Field shopid = new Field("shopid",rs.getString("shop_id"),Field.Store.YES, Field.Index.NO);//一个完整的索引多个域组成(field) 在这里有3个 分别是shopid,以及下面的goodsid,FieldBody; 我打个比方说,我们对一篇文章做全文检索的索引,我们可以分别把文章的保存路径,文章的标题,文章的正文内容作为3个field,然后一起通过下面的document.add保存到一个Document对象中,那么在检索的时候,我们在正文中查找到目标字段,同时我们可以做到把该文档的保存路径以及标题也取到; Field goodsid = new Field("goodsid",goods_id,Field.Store.YES, Field.Index.NO);//不做索引 Field FieldBody = new Field( "body" , rs.getString("shopname")+" "+rs.getString("goodsname"), Field.Store.YES,Field.Index.TOKENIZED,Field.TermVector.WITH_POSITIONS_OFFSETS); document.add(shopid); document.add(goodsid); document.add(FieldBody); //把索引字段添加到行对象中 indexWriter.addDocument(document); //把一行信息加入到输出流中 } indexWriter.optimize(); /mit 写出到硬盘上 indexWriter.close(); // 关闭流 } public static void main(String[] args) throws CorruptIndexException, ClassNotFoundException, SQLException, IOException { queryDB(); System.out.println("创建索引成功"); } //如果还有什么不明白的可以直接M我,有时间的话,可以回答一点简单的问题 }

老周互联24小时无理由退款,香港原生IP,28元起

老周互联怎么样?老周互联隶属于老周网络科技部旗下,创立于2019年12月份,是一家具有代表性的国人商家。目前主营的产品有云服务器,裸金属服务器。创办一年多以来,我们一直坚持以口碑至上,服务宗旨为理念,为用户提供7*24小时的轮班服务,目前已有上千多家中小型站长选择我们!服务宗旨:老周互联提供7*24小时轮流值班客服,用户24小时内咨询问题可提交工单,我们会在30分钟内为您快速解答!另免费部署服务器...

美得云(15元/月)美国cera 2核4G 15元/月 香港1核 1G 3M独享

美得云怎么样?美得云好不好?美得云是第一次来推广软文,老板人脾气特别好,能感觉出来会用心对待用户。美得云这次为大家提供了几款性价比十分高的产品,美国cera 2核4G 15元/月 香港1核 1G 3M独享 15元/月,并且还提供了免费空间给大家使用。嘻嘻 我也打算去白嫖一个空间了。新用户注册福利-8折优惠码:H2dmBKbF 截止2021.10.1结束。KVM架构,99.99%高可用性,依托BGP...

inux国外美老牌PhotonVPS月$2.5 ,Linux系统首月半价

PhotonVPS 服务商我们是不是已经很久没有见过?曾经也是相当的火爆的,我们中文习惯称作为饭桶VPS主机商。翻看之前的文章,在2015年之前也有较多商家的活动分享的,这几年由于服务商太多,乃至于有一些老牌的服务商都逐渐淡忘。这不有看到PhotonVPS商家发布促销活动。PhotonVPS 商家七月份推出首月半价Linux系统VPS主机,首月低至2.5美元,有洛杉矶、达拉斯、阿什本机房,除提供普...

lucene为你推荐
raxRax 徒步鞋怎么样,好不好链接转换一个VB程序,简单的链接转换,怎么做?中国银行卡号中国银行卡号是几位数?provisionedNIST的云计算定义rbooracle中rbo和cbo的区别运行时错误1004excel 打开表格提示 运行是错误1004,本人不会用宏和VB,只是表格内数据显示不出来色温图色温是什么意思?色温图表jspushjavascript数组 如果一直只做push 那么数组的index为-1的地方是什么值阶乘函数C语言中有计算阶乘的函数吗 不是自己写,,,是那种可以直接调用的函数vrrp配置我准备做一个关于MSTP的配置,但是不知道如何去做,拓扑如下
主机域名 便宜域名注册 国外vps 最便宜的vps la域名 国内php空间 租空间 国外在线代理 共享主机 最好的qq空间 网通服务器托管 gtt 酷番云 shopex主机 dnspod 智能dns解析 浙江服务器 攻击服务器 沈阳idc 月付空间 更多