hibernate search 实体映射


在实体映射,多层次关联:

//双向一对多

Salesman.java:

@OneToMany(mappedBy="salesman",cascade = CascadeType.ALL)//双向一对多
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)  
@ContainedIn
private Set<CarOrder> carOrders = new HashSet();


@Cache(usage = CacheConcurrencyStrategy.READ_WRITE) 
@IndexedEmbedded(depth=1)//嵌入和关联实体映射
private Address address;


address.java:

@Field(name="city",index=Index.TOKENIZED)//嵌入和关联实体映射
@Column
private String city;



CarOrder.java:

@ManyToOne
@JoinColumn(name = "salesId")
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
@IndexedEmbedded(depth=2)//嵌入和关联实体映射
private Salesman salesman;


Test.java:

void queryEntity() throws Exception{//处理实体映射的QueryBuilder方法

		session = sf.openSession();
		FullTextSession fullTextSession=Search.getFullTextSession(session);
		Transaction tx = fullTextSession.beginTransaction();
		
		QueryBuilder qb = fullTextSession.getSearchFactory().buildQueryBuilder().forEntity( CarOrder.class ).get();
		//查询是把salesman.address.city替换就可获取其他结果,如carName就可以直接获取本身的值,并不用通过关联来获取值
	    org.apache.lucene.search.Query query = qb.keyword().onFields("salesman.address.city").matching("军恶").createQuery();

	    org.hibernate.Query hibQuery = fullTextSession.createFullTextQuery(query, CarOrder.class);

	    List result = hibQuery.list();
	    for(int i=0;i<result.size();i++)
	     {
	    	CarOrder bc3 = (CarOrder) result.get(i);
	    	 System.out.println("id for the selected basiccar is:"
	    			 +bc3.getSalesman().getAddress().getCity());	    	 	    	     	 
	     }
		
	    tx.commit();
		session.close();
	 }
	


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值