package org.itat.text1; import java.io.File; import java.io.IOException; import javax.management.Query; import org.apache.lucene.analysis.standard.StandardAnalyzer; import org.apache.lucene.document.Document; import org.apache.lucene.document.Field; import org.apache.lucene.index.CorruptIndexException; import org.apache.lucene.index.IndexReader; import org.apache.lucene.index.IndexWriter; import org.apache.lucene.index.IndexWriterConfig; import org.apache.lucene.index.Term; import org.apache.lucene.store.Directory; import org.apache.lucene.store.FSDirectory; import org.apache.lucene.store.LockObtainFailedException; import org.apache.lucene.util.Version; class IndexUtil_11 { private String [] ids={"1","2","3","4"}; private String [] emails={"lele@qq.com","1534432371@qq.com","hello@sine.com","Tom@163.com"}; private String [] contents={"Hello world!","lele is so cool!","hello@sine.com","Tom@163.com"}; private String [] names={"lele!","Tom","zhangsan ","zhaosi"}; private int [] attachs={1,2,3,5}; private Directory directory=null; public void index() { //创建Derectory try { directory=FSDirectory.open(new File ("G:/Lucene/indext2")); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } // 创建Writer IndexWriter writer=null; try { writer=new IndexWriter (directory, new IndexWriterConfig(Version.LUCENE_35, new StandardAnalyzer(Version.LUCENE_35))); Document doc=null; for (int i=0;i<ids.length;i++) { //创建Decoment并添加Field doc=new Document(); doc.add(new Field("ids",ids[i],Field.Store.YES,Field.Index.NOT_ANALYZED_NO_NORMS)); doc.add(new Field("names",names[i],Field.Store.YES,Field.Index.NOT_ANALYZED_NO_NORMS)); doc.add(new Field("emails",emails[i],Field.Store.YES,Field.Index.NOT_ANALYZED)); doc.add(new Field("contents",contents[i],Field.Store.NO,Field.Index.ANALYZED)); //将文档写到索引中 writer.addDocument(doc); } } catch (CorruptIndexException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (LockObtainFailedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (writer!=null) { try { writer.close(); } catch (CorruptIndexException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); //throw new Exception (); } } } } public void unDelete()//恢复回收站中未被删除的东西 { try { //恢复时必须把IndexReader的只读设置为false IndexReader reader=IndexReader.open(directory,false); reader.undeleteAll(); reader.close(); } catch (CorruptIndexException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } public void updata() { IndexWriter writer=null; try { writer=writer=new IndexWriter (directory, new IndexWriterConfig(Version.LUCENE_35, new StandardAnalyzer(Version.LUCENE_35))); Document doc=new Document(); //更新就是先删除后添加 doc.add(new Field("ids","11",Field.Store.YES,Field.Index.NOT_ANALYZED_NO_NORMS)); doc.add(new Field("names",names[0],Field.Store.YES,Field.Index.NOT_ANALYZED_NO_NORMS)); doc.add(new Field("emails",emails[0],Field.Store.YES,Field.Index.NOT_ANALYZED)); doc.add(new Field("contents",contents[0],Field.Store.NO,Field.Index.ANALYZED)); writer.updateDocument(new Term("ids","2"), doc); } catch (CorruptIndexException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (LockObtainFailedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (writer!=null) {try { writer.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }} } } public void forceDelete()//强制删除回收站中的东西 {IndexWriter writer=null; try { writer=writer=new IndexWriter (directory, new IndexWriterConfig(Version.LUCENE_35, new StandardAnalyzer(Version.LUCENE_35))); writer.forceMergeDeletes(); } catch (CorruptIndexException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (LockObtainFailedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (writer!=null) {try { writer.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }} } } public void delete()//删除文档到回收站中 { IndexWriter writer=null; try { writer=writer=new IndexWriter (directory, new IndexWriterConfig(Version.LUCENE_35, new StandardAnalyzer(Version.LUCENE_35))); writer.deleteDocuments(new Term("names","Tom")); } catch (CorruptIndexException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (LockObtainFailedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { if (writer!=null) {try { writer.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }} } } public void query() throws IOException { try { //通过IndexReader进行查询 IndexReader reader=IndexReader.open(directory); //通过reader可以有效的获取文档的数量 System.out.println(reader.numDocs()); System.out.println(reader.maxDoc()); System.out.println("Delete : "+reader.numDeletedDocs()); reader.close(); } catch (CorruptIndexException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
package org.itat.text1; import java.io.IOException; public class IndexText { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub IndexUtil_11 indextUtil=new IndexUtil_11(); indextUtil.index(); indextUtil.delete(); indextUtil.forceDelete(); indextUtil.updata(); //indextUtil.query(); try { //indextUtil.unDelete(); indextUtil.query(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }