java开源文档大全致力于打造中国最大最全的开源文档,它提供了最全面最权威的开源资料,同时为大家提供一个交流的平台,如果您有好的想法,欢迎您投稿.
最近在项目中使用Spring和Hibernate框架进行开发,有感于Criteria比较好用,在查询方法设计上可以灵活的根据Criteria的特点来方便地进行查询条件的组装。所以现在对Hibernate框架的Criteria深入研究一下。《Hibernate框架 Reference》及网上其它一些资料对Criteria已经做了很多介绍。本文主要是从Criteria的结构入手来进行分析。 如图1。Hibernate框架设计了CriteriaSpecification作为Criteria的顶级接口,其下面提供了Criteria和DetachedCriteria。 Criteria和DetachedCriteria的主要区别在于创建的形式不一样,Criteria是在线的,所以它是由Hibernate框架 Session进行创建的;而DetachedCriteria是离线的,创建时无需Session,DetachedCriteria提供了4个静态方法forClass(Class)或forEntityName(Name)进行DetachedCriteria实例的创建。Spring的框架提供了 getHibernate框架Template().findByCriteria(detachedCriteria)方法可以很方便地根据 DetachedCriteria来返回查询结果。 如图1,Criteria和DetachedCriteria均可使用Criterion和Projection设置查询条件。可以设置FetchMode(联合查询抓取的模式),设置排序方式。对于Criteria还可以设置FlushModel(冲刷Session的方式)和LockMode(数据库锁模式)。 下面就对Criterion和Projection进行详细说明。  图1 Criterion是Criteria的查询条件。 Criteria提供了add(Criterion criterion)方法来添加查询条件。图2是Criterion的结构图。Criterion接口的主要实现包括:Example、Junction和SimpleExpression。而Junction的实际使用是它的两个子类conjunction和disjunction,分别是使用AND和OR操作符进行来联结查询条件集合。 Criterion的实例可以通过Restrictions工具类来创建,Restrictions提供了大量的静态方法,如eq(等于)、ge(大于等于)、between等来方法的创建Criterion查询条件 (SimpleExpression实例)。除此之外,Restrictions还提供了方法来创建conjunction和disjunction实例,通过往该实例的add(Criteria)方法来增加查询条件形成一个查询条件集合。 至于Example的创建有所不同,Example本身提供了一个静态方法create(Object entity),即根据一个对象(实际使用中一般是映射到数据库的对象)来创建。然后可以设置一些过滤条件: Example exampleUser =Example.create(u) .ignoreCase() //忽略大小写 .enableLike(MatchMode.ANYWHERE); //对String类型的属性,无论在那里值在那里都匹配。相当于%value%
 图2 Project 主要是让Criteria能够进行报表查询,并可以实现分组。Project主要有SimpleProjection、ProjectionList和Property三个实现。其中SimpleProjection和ProjectionList的实例化是由内建的Projections来完成,如提供的avg、count、max、min、sum可以让开发者很容易对某个字段进行统计查询。 Property是对某个字段进行查询条件的设置,如通过 Porperty.forName(“color”).in(new String[]{“black”,”red”,”write”});则可以创建一个Project实例。通过criteria的add(Project)方法加入到查询条件中去。
 图3 使用Criteria进行查询,主要要清晰的是Hibernate框架提供了那些类和方法来满足开发中查询条件的创建和组装,其结构层次如何。这样使用起来便可得心应手。
java开源文档研究struts,webwork,spring,tomcat,jboss,lucense,nutch,JUnit,eclipse......,如果您有什么意见,欢迎评论和留言. |