lucene的Filter查询的过滤器,

/*

* Filter这个类的功能是实现对于查询的过滤器,

* 对于用户搜索的,可以把保密的网站或者文档对用户不进行显示

* 例如:

* 这里就是一个图书馆的查询系统,图书馆的有些珍贵资料是不予显示的。

* 只有高级权限的(Advanced)的用户才可以显示

*

* */

package filter;

import java.io.IOException;

import org.apache.lucene.analysis.standard.StandardAnalyzer;

import org.apache.lucene.document.Document;

import org.apache.lucene.document.Field;

import org.apache.lucene.index.IndexReader;

import org.apache.lucene.index.IndexWriter;

public class FilterOneTest {

private final int SECURITY_ADVANCED = 1;

private final int SECURITY_MIDDLE = 2;

private final int SECURITY_NORMAL = 3;

public FilterOneTest(String INDEX_STORE_PATH) {

try{

IndexWriter writer = new IndexWriter(INDEX_STORE_PATH, new StandardAnalyzer(), true);

writer.setUseCompoundFile(false);

Document doc1 = new Document();

Field f1 = new Field("bookNumber", "0000003", Field.Store.YES, Field.Index.UN_TOKENIZED);

Field f2 = new Field("bookname", "论宇称非对称模型", Field.Store.YES, Field.Index.TOKENIZED);

Field f3 = new Field("publishdate", "1999-01-01", Field.Store.YES, Field.Index.UN_TOKENIZED);

Field f4 = new Field("securitylevel", SECURITY_ADVANCED + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc1.add(f1);

doc1.add(f2);

doc1.add(f3);

doc1.add(f4);

Document doc2 = new Document();

f1 = new Field("bookNumber", "0000005", Field.Store.YES, Field.Index.UN_TOKENIZED);

f2 = new Field("bookname", "钢铁战士", Field.Store.YES, Field.Index.TOKENIZED);

f3 = new Field("publishdate", "1995-07-15", Field.Store.YES, Field.Index.UN_TOKENIZED);

f4 = new Field("securitylevel", SECURITY_MIDDLE + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc2.add(f1);

doc2.add(f2);

doc2.add(f3);

doc2.add(f4);

Document doc3 = new Document();

f1 = new Field("bookNumber", "0000001", Field.Store.YES, Field.Index.UN_TOKENIZED);

f2 = new Field("bookname", "相对论", Field.Store.YES, Field.Index.TOKENIZED);

f3 = new Field("publishdate", "1963-02-14", Field.Store.YES, Field.Index.UN_TOKENIZED);

f4 = new Field("securitylevel", SECURITY_ADVANCED + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc3.add(f1);

doc3.add(f2);

doc3.add(f3);

doc3.add(f4);

Document doc4 = new Document();

f1 = new Field("bookNumber", "0000006", Field.Store.YES, Field.Index.UN_TOKENIZED);

f2 = new Field("bookname", "黑猫警长", Field.Store.YES, Field.Index.TOKENIZED);

f3 = new Field("publishdate", "1988-05-01", Field.Store.YES, Field.Index.UN_TOKENIZED);

f4 = new Field("securitylevel", SECURITY_ADVANCED + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc4.add(f1);

doc4.add(f2);

doc4.add(f3);

doc4.add(f4);

Document doc5 = new Document();

f1 = new Field("bookNumber", "0000004", Field.Store.YES, Field.Index.UN_TOKENIZED);

f2 = new Field("bookname", "原子弹的爆破过程", Field.Store.YES, Field.Index.TOKENIZED);

f3 = new Field("publishdate", "1959-10-21", Field.Store.YES, Field.Index.UN_TOKENIZED);

f4 = new Field("securitylevel", SECURITY_ADVANCED + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc5.add(f1);

doc5.add(f2);

doc5.add(f3);

doc5.add(f4);

Document doc6 = new Document();

f1 = new Field("bookNumber", "0000007", Field.Store.YES, Field.Index.UN_TOKENIZED);

f2 = new Field("bookname", "钢铁是怎样炼成的", Field.Store.YES, Field.Index.TOKENIZED);

f3 = new Field("publishdate", "1970-01-11", Field.Store.YES, Field.Index.UN_TOKENIZED);

f4 = new Field("securitylevel", SECURITY_MIDDLE + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc6.add(f1);

doc6.add(f2);

doc6.add(f3);

doc6.add(f4);

Document doc7 = new Document();

f1 = new Field("bookNumber", "0000002", Field.Store.YES, Field.Index.UN_TOKENIZED);

f2 = new Field("bookname", "白毛女", Field.Store.YES, Field.Index.TOKENIZED);

f3 = new Field("publishdate", "1977-09-07", Field.Store.YES, Field.Index.UN_TOKENIZED);

f4 = new Field("securitylevel", SECURITY_NORMAL + "", Field.Store.YES, Field.Index.UN_TOKENIZED);

doc7.add(f1);

doc7.add(f2);

doc7.add(f3);

doc7.add(f4);

writer.addDocument(doc1);

writer.addDocument(doc2);

writer.addDocument(doc3);

writer.addDocument(doc4);

writer.addDocument(doc5);

writer.addDocument(doc6);

writer.addDocument(doc7);

writer.close();

IndexReader reader = IndexReader.open(INDEX_STORE_PATH);

for(int i = 0; i < reader.numDocs(); i++){

Document doc = reader.document(i);

System.out.print("书号:");

System.out.println(doc.get("bookNumber"));

System.out.print("书名:");

System.out.println(doc.get("bookname"));

System.out.print("发布日期:");

System.out.println(doc.get("publishdate"));

System.out.print("安全级别:");

System.out.print(doc.get("securitylevel"));

int level = Integer.parseInt(doc.get("securitylevel"));

switch(level){

case SECURITY_ADVANCED:

System.out.println("高级");

break;

case SECURITY_MIDDLE:

System.out.println("中级");

break;

case SECURITY_NORMAL:

System.out.println("一般");

break;

}

System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>");

}

}catch(IOException e){

e.printStackTrace();

}

}

public static void main(String[] args) {

// TODO Auto-generated method stub

FilterOneTest fot = new FilterOneTest("E:\\Lucene项目\\索引文件");

}

}

时间: 2024-08-04 22:40:24

lucene的Filter查询的过滤器,的相关文章

Lucene6去掉了Filter但是可以用BooleanQuery实现Filter查询

Lucene在6.0版本之后彻底废除了Filter的使用,采用BooleanQuery来实现Filter的功能,核心代码如下: TermQuery termQuery = new TermQuery(new Term("content","长")); TermQuery termQuery1 = new TermQuery(new Term("content","格")); BooleanQuery.Builder build

HBase Client API使用入门(二)---查询及过滤器

相关知识 创建表插入数据删除等见:http://www.cnblogs.com/wishyouhappy/p/3735077.html HBase API简介见:http://www.cnblogs.com/wishyouhappy/p/3753347.html 按行.列簇等查询 package wish.hbase; import java.io.IOException; import java.util.ArrayList; import java.util.List; import org

Introducation of Servlet filter(servlet过滤器介绍 )

本文章向大家介绍Servlet Filter,主要包括 Servlet Filter使用实例.应用技巧.基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下. 过滤器是一个可以转换请求或响应的标头和内容(或两者)的对象.过滤器与Web组件的不同之处在于过滤器通常不会自行创建响应.相反,过滤器提供可以“附加 ”到任何类型的Web资源的功能.因此,过滤器不应该对作为过滤器的Web资源有任何依赖性; 这样,它可以由多种类型的Web资源组成. 过滤器可以执行的主要任务如下. 查询请求

lucene 转义含有查询关键词的字符的

http://www.oschina.net/question/1092_560 Escaping Special Characters Lucene支持转义查询中的特殊字符,以下是Lucene的特殊字符清单:+ - && || ! ( ) { } [ ] ^ " ~ * ? : \ 转义特殊字符我们可以使用符号“\”放于字符之前.比如我们要搜索(1+1):2,我们可以使用如下语法:\(1\+1\)\:2 lucene自带函数 QueryParser.escape(q)  可转换

ELK学习总结(3-2)elk的filter查询过滤

和一般查询比较,filter查询能够缓存数据,应该尽可能使用 建立测试数据 查看测试数据 1.filtered查询 GET /store/products/_search { "query":{ "filtered":{ "query": { "match_all":{} }, filter:{ "terms":{ "price":[10,20] } } } } } ## 调用没有得到结

开发指南专题七:JEECG微云快速开发平台查询HQL过滤器

开始学习wxWidgets,上一篇写了"安装wxWidgets遭遇的两大关卡"(简称"前文"). 先推荐一下这两天找到的学习材料. 博客中有一个系列教程,貌似作者没有写完,见<跟我学wxWidgets开发>系列教程. 要看书,就<使用wxWidgets进行跨平台程序开发>.我给的链接中,包括中书中的源码.这本书,是<Cross Platform GUI Programming With wxWidget>的中译本,译本中没有附录部

servlet/filter/listener/interceptor过滤器、监听器、拦截器区分

因为之前一直分不清过滤器和拦截器的区别,所以有了两者差不多的错觉,因此在这里总结下servlet/filter/listener/interceptor过滤器.监听器.拦截器. 在此之前先简单回顾下servlet: 概述:servlet是一种运行服务器端的java应用程序,它工作在客户端请求与服务器响应的中间层. 主要作用:在于交互式地浏览和修改数据,生成动态 Web 内容. 访问流程: 1,客户端发送请求至服务器端: 2,服务器将请求信息发送至 Servlet: 3,Servlet 生成响应内

Bloom Filter(布隆过滤器)

布隆过滤器(英语:Bloom Filter)是1970年由布隆提出的.它实际上是一个很长的二进制矢量和一系列随机映射函数.布隆过滤器可以用于检索一个元素是否在一个集合中.它的优点是空间效率和查询时间都远远超过一般的算法,缺点是有一定的误识别率和删除困难. 如果想判断一个元素是不是在一个集合里,一般想到的是将集合中所有元素保存起来,然后通过比较确定.链表.树.散列表(又叫哈希表,Hash table)等等数据结构都是这种思路.但是随着集合中元素的增加,我们需要的存储空间越来越大.同时检索速度也越来

Django object filter查询[转]

用PYTHON ,DJANGO 做站,在通常的情况下,需要用到 orM 的查询方法,比如object.filter(tag__contains='keywords').... 在这种情况下,如果你跟踪 sql 语句,你会发现,SQL 语句会生成 select .... like bianry '%keywords%', 如果是这样的语句,在某些情况是下是会出问题的,也就是说查询出来的数据可能会比你预计的少. 如果你用 raw sql 查总数 select count(*) from table