之前做开发是用公司的框架,很多东西都是别人包装好的。所以,很多细节不用考虑。只要懂了框架,
开发起来只考虑业务即可。这也是框架的最大的好处:着眼于业务逻辑的实现,而非技术细节的实现。
最近几天在使用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();
可以实现。是最终比较合适的方法。