繁体   English   中英

如何使用QueryBuilder,Lucene Query和FullTextQuery显示休眠搜索结果?

[英]How to display hibernate search results using QueryBuilder, Lucene Query & FullTextQuery?

如何仅使用带有Order子句的FullTextEntity Manager显示结果。

  EntityManager em = factory.createEntityManager();
  FullTextEntityManager fullTextEntityManager = Search.getFullTextEntityManager(em);
  QueryBuilder qb = fullTextEntityManager.getSearchFactory()
                        .buildQueryBuilder().forEntity( Desh.class ).get();

  org.apache.lucene.search.Query query = new org.apache.lucene.search.MatchAllDocsQuery();
  //Also used qb.all().getQuery(); but no results

  FullTextQuery fullTextQuery = fullTextEntityManager.createFullTextQuery(query, Desh.class);
  System.out.println(""+ query);
  System.out.println(""+ query.toString());

  fullTextQuery.setSort(new Sort(new SortField("DeshName_for_sort", SortField.STRING, true)));
  //Also used DESH but no results

  fullTextQuery.setFirstResult(0).setMaxResults(60);
  System.out.println("" + fullTextQuery);  
  System.out.println("" + fullTextQuery.getParameters());

  int size = fullTextQuery.getResultSize();
  List<Desh> result = fullTextQuery.getResultList();
  System.out.println("Size e -> "+ size);
  System.out.println("Size e -> "+ result.size());
  for (Deshuser : result) {
    System.out.println("Id: " + user.getId());
    System.out.println("Person Id:" + user.getName());
  }

Desh-实体类:

@Entity
@Table(name = "DESH")
@XmlRootElement
@Indexed

public class Desh implements Serializable {
 private static final long serialVersionUID = 1L;
@Id
@Basic(optional = false)
@Column(name = "ID")
private Long id;

@Fields({ @Field(index = Index.YES, store = Store.NO), @Field(name = "DeshName_for_sort", index = Index.YES, analyze = Analyze.NO) })
@Column(name = "NAME", length = 100)
private String name;

public Desh () {
}

public Desh (Long id) {
    this.id = id;
}

public Desh (Long id) {
    this.id = id;

}

public Long getId() {
    return id;
}

public void setId(Long id) {
    this.id = id;
}



public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}


@Override
public String toString() {
    return "in.hibprac.hibernatepractice.Desh[ id=" + id + " ]";
}

}

当我运行以上程序时,它不返回任何大小。 但是,当我使用Namedquery和Native Query返回时,它执行得很好。 即使我删除代码中的排序语句,也不会返回任何内容。 谁能指导我问题出在哪里?

尝试这个 :

FullTextEntityManager ftem=Search.getFullTextEntityManager(entityManager);
ftem.createIndexer().startAndWait();

启动以所有标有@Indexed注释的实体为目标的@Indexed

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM