hibernate里的findByExample(原创)

之前做开发是用公司的框架,很多东西都是别人包装好的。所以,很多细节不用考虑。只要懂了框架,
开发起来只考虑业务即可。这也是框架的最大的好处:着眼于业务逻辑的实现,而非技术细节的实现。

最近几天在使用hibernate做开发。
遇到了一个问题:
hibernate里使用findByExample的时候,默认的实现方法是:

 public List findByExample(Sim obj) {
  List results = session.createCriteria((obj.getClass().getName())
    .add(Example.create(obj)).list();
  return results;
 }
使用这个方法的原因是:我们希望我们可以任意的传字段进去,穿进去哪个字段就对哪个字段进行匹配。
默认的会忽略为null的字段(注意是null,如果一个字段默认是“”或者false或者0.0,那么就会出错)。
这个问题遇到过,hibernate进行查询的时候,创建一个对象,我们没有赋值给的字段就会使用默认字段进行
填充,如:boolean=》false double=》0.0 。我们真正想要的是这个字段为null,这样在findByExample的时候我们就可以进行忽略了。
事实上这个字段会使用默认值进行匹配,所以就会出错。====》解决:我们将实体类和hbm.xml里的long、int、boolean改为他们对应的包装类
,这样当我们创建对象,不赋值的时候,这个字段默认为null。使用findByExample进行匹配的时候默认忽略字段为null的。

但是,有个问题:我们希望对type里的某一个或多个字段进行限制,当我们把Type对象set进去到Sim之后,使用findByExample是不行的。
因为findByExample忽略关联的。我曾经尝试:
     Query q =
   session.createQuery("from Sim s where s.type ="+obj.getType().getId()+" and s.simNumber like '%"+obj.getSimNumber()+"%'");
   List results = q.list();

这种是可以的,但是过于死板。

使用:
    List results = session.createCriteria(Sim.class)
    .add(Example.create(obj)).createCriteria("type")
    .add(Example.create(obj.getType())).list();

还是对type里的限制不了。

最后使用:
     List results = session.createCriteria(Sim.class)
     .add( Restrictions.like("simNumber", "%"+obj.getSimNumber()+"%"))
     .createCriteria("type")
         .add(Restrictions.eq("id", obj.getType().getId()))
     .list();
  
可以实现。是最终比较合适的方法。

你可能感兴趣的:(Hibernate)