hibernate高级应用

DML风格的批量更新和删除

语法格式:
delete | update from? [Where condition]
from是可选的,可以不写。from字句后面只能有一个类名。可以指定别名。
可以使用where字句查询但不能使用连接。

String hqlUpdate = "update User u set name=:newName";
int updateEntities = session.creaateQuery(hqlUpdate).setString("newName","新名字").executeUpdate();
String hqlDelete = "delete User";
int deleteEntities = session.createQuery(hqlDelete).executeUpdate();

HQL查询

  1. 获取session对象
  2. 编写HQL语句
  3. session.createQuery(hql)创建查询对象
  4. 调用Query.setXXX方法设置查询参数
  5. 调用Query对象的list()或uniqueResult()返回查询结果。
List p1 = session.createeQuery("select distinct p from Person p
            join p.myEvents where title = :eventTitle")
            .setString("eventTitle","很普通")
            .list();

List p2 = session.createeQuery("select distinct p from Person p
            inner join p.myEvents events where event.happenDate between :firstDate and :endDate")
            .setDate("firstDate",new Date())
            .setDate("lastDate",new Date())
            .list();

条件查询

  • Creteria:代表依次查询
  • Criterion:代表一个查询条件
  • Restrictions:产生查询条件的工具类。
    执行条件查询的步骤:
    1. 获得session
    2. session创建criteria对象。
    3. 使用Restrictions的静态方法创建Criterion对象。
    4. 向Criteria对象添加Criterion查询条件。
      5 执行Criteria的list()或uniqueResult()。
List list = session.createCriteria(Student.class)
                    .add(Restrictions.gt("name","a"))
                    .list():

Cretiria还有如下方法:
setFirstResult(int);
setMaxResult(int);
addOrder(Order order)

分组、投影、聚合

使用Projection代表投影运算。Projection是一个接口,而Projections作为Projection的 工厂。负责生产Projection对象。

List cats = session.createCriteria(Cat.class)
                    .setProjection(Projections.projectionList()
                    .add(Projection.rowCOunt())
                    .add(Projection.avg("weight"))
                    .add(Projection.groupProperty("color"))
                    .addOrder(Order.asc("color"))
                    )
                    .list();

离线查询和子查询

使用DetachedCriteria实现。

//离线查询
DetachedCriteria query = DetachedCriteria
            .forClass(Student.class)
            .setProjection(Property.forName("name"));
        Session session = HibernateUtil.currentSession();
        Transaction tx = session.beginTransaction();
        List list = query.getExecutableCriteria(session)
            .list();

//子查询
List list = session.createCriteria(Student.class)
            //下面两种方式都行
            .add( Property.forName("name").in(query))
//          .add( Subqueries.propertyIn("name" , query))
            .list();

SQL查询

通过Query的子接口SQLQuery.它多了两个方法:
addEntity():将查询到的记录与特定的实体相关联。
addScalar():将查询到的记录关联成标量值。

//明确指定查询中返回的数据列返回的类型
session.createSQLQeury("select * from student_inf")
       .addScalar("name",StandardBasicTypes.STRING)
       .list();

//实体查询
String sql = "select * from enroment_inf where year=?1";
List list = session.createSQLQuery(sql)
            .addEntity(Enrolment.class)
            .setInteger("1",2005)
            .list();
//映射多个实体
String sqlString = "select s.*,e.*,c.* "
            + "from student_inf s,enrolment_inf e,course_inf c "
            + "where s.student_id = e.student_id "
            + "and e.course_code = c.course_code";
        List list = session.createSQLQuery(sqlString)
            .addEntity("s", Student.class)
            .addEntity("e", Enrolment.class)
            .addEntity("c", Course.class)
            .list();
for (Object ele : list)
        {
            Object[] objs = (Object[])ele;
            Student s = (Student)objs[0];
            Enrolment e = (Enrolment)objs[1];
            Course c = (Course)objs[2];
            System.out.println(s.getName() + "\t"
                + e.getYear() + "\t" + e.getSemester()
                + "\t" + c.getName());
        }

还可将查询结果转换成非持久化类。(javabean).Query接口有个setResultTransformer()方法。传进一个Transformers对象即可转换。

String sqlString = "select s.name stuName, c.name courseName "
            + "from student_inf s,enrolment_inf e,course_inf c "
            + "where s.student_id = e.student_id "
            + "and e.course_code = c.course_code ";
        List list = session.createSQLQuery(sqlString)
            .setResultTransformer(Transformers
                .aliasToBean(StudentCourse.class))
            .list();
//StudnetCourse只有两个属性stuName,courseName。

处理关联和映射

将关联实体转换成查询结果
SQLQuery.addJoin(String alias,String property):第一个是转换后的实体名,第二个是待转换的实体属性。

String sqlString = "select s.* , e.* from student_inf s , "
        + "enrolment_inf e where s.student_id=e.student_id";
    List list = session.createSQLQuery(sqlString)
        .addEntity("s", Student.class)
        .addJoin("e" , "s.enrolments")
        .list();
    for (Object ele : list)
    {
        Object[] objs = (Object[])ele;
        Student s = (Student)objs[0];
        Enrolment e = (Enrolment)objs[1];
        System.out.println(s.getName() + "\t" + e.getYear());
    }

命名sql查询

可以使用@NamedNativeQuery来定义原生sql查询。有如下属性:

name:查询名称
query:sql语句
resultClass:查询映射的实体类的类名
resultSetMapping:指定一个sql结果映射

如果需要使用resultresultSetMapping属性。则需要使用@SqlResultSetMapping定义sql结果映射。
将查询得到的结果转换为标量查询或实体查询。
@SqlResultSetMapping有以下属性:

name:
columns:值为@ColumnResult注解数组。每个@ColumnResult定义一个标量查询。
entities:值为@EntityResult注解数组。每个@EntityResult定义一个实体查询
classes:值为@ConstructorResult注解数组。每个@ConstructorResult负责将指定的多列转换为javabean的对应属性。

@NamedNativeQueries({
@NamedNativeQuery(name="simpleQuery"
    , query="select s.student_id , s.name from student_inf s"
    , resultClass=Student.class),

@NamedNativeQuery(name="queryTest"
    , query="select s.*,e.*,c.* from student_inf s,enrolment_inf e,"
    + " course_inf c where s.student_id = e.student_id and"
    + " e.course_code = c.course_code and e.year=:targetYear"
    , resultSetMapping = "firstMapping"),

@NamedNativeQuery(name="callProcedure"
    , query="{call select_all_student()}"
    , resultSetMapping = "secondMapping")
})
@SqlResultSetMappings({
@SqlResultSetMapping(name="firstMapping"
    , entities={@EntityResult(entityClass=Student.class),
        @EntityResult(entityClass=Enrolment.class),
        @EntityResult(entityClass=Course.class , fields=
        {
            @FieldResult(name="courseCode" , column="c.course_code"),
            @FieldResult(name="name" , column="c.name")
        })
    }
    , columns={@ColumnResult(name="s.name" , type=String.class)}
),
@SqlResultSetMapping(name="secondMapping"
    , entities={@EntityResult(entityClass=Student.class , fields=
        {
            @FieldResult(name="studentNumber" , column="student_id"),
            @FieldResult(name="name" , column="name")
        })
    })
})
//调用
List list = session.getNamedQuery("queryTest")
            .setInteger("targetYear" , 2005)
            .list();
for(Object ele : list)
        {
            Object[] objs = (Object[])ele;
            Student s = (Student)objs[0];
            Enrolment e = (Enrolment)objs[1];
            Course c = (Course)objs[2];
            String stuName = (String)objs[3];
            System.out.println(s.getName() + "\t"
                + e.getYear() + "\t" + e.getSemester()
                + "\t=" + e.getCourse().getName() + "=\t" + stuName);
        }

调用存储过程

可以通过命名sql查询来调用存储过程或函数。对于函数,该函数必须返回一个结果集。对于存储过程,该存储过程的第一个参数必须是参数,且其数据类型必须是结果集。

//创建一个简单的存储过程
create procedure select_all_student()
select * from student_inf;

//定义一个调用存储过程的命名sql
@NameNativeQuery(name="callProcedure"
                    ,query="{call select_all_student()}"
                    ,resultSetMapping="secondMapping")
@SqlResultSetMapping(name="secondMapping"
                ,entities={@EntityResult(entityClass=Student.class,fileds=
                {
                    @FieldResult(name="studentNumber",column="student_id"),
                    @FieldResult(name="name",column="name")
                })
            })
//调用存储过程
List list = session.getNamedQuery("callProcedure")
            .list();

使用定制sql

不使用hibernate提供的默认sql语句来执行。而使用自己写的。
如果想要调用存储过程来执行删除,更新等操作。则需指定callable=true.

@SQLInsert(callable=true,sql="{call createPerson(?,?)}")
@SQLUpdate(callable=true,sql="{? = call UpdatePerson(?)}")
@SQLDelete(callable=true,sql="{? = call deletePerson(?,?)}")

还可用命名sql实现定制装载。例如在装载News时为title属性的前后增加三个等号。

@SQLInsert(sql="insert into news_inf(content , title) values(upper(?), ?)")
@SQLUpdate(sql="update news_inf set content=upper(?), title=? where news_id=?")
@SQLDelete(sql="delete from news_inf where news_id=?")
@SQLDeleteAll(sql="delete from news_inf")
@Loader(namedQuery = "news_loader")
@NamedNativeQuery(name="news_loader"
    , query="select news_id , concat('===' , concat(title , '===')) as title"
        + " , content from news_inf n where news_id=?"
    , resultClass = News.class)
@Entity
@Table(name="news_inf")
public class News
{
    @Id @Column(name="news_id")
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    private Integer id;
    private String title;
    private String content;

数据过滤

过滤器与持久化类的@Where注解非常相似。他们的区别是过滤器可以带参数,运用程序可以在运行时决定是否启动指定的过滤器。使用怎样的参数值。而@Where注解将一直生效。且无法动态传入参数。
使用过滤器的三个步骤:
1. 定义过滤器,使用hibernate提供的@FilterDef注解定义过滤器。如果需要定义多个过滤器则需要使用@FilterDefs注解组合多个@FilterDef.
2. 使用@Filter元素应用过滤器
3. 在代码中通过session启用过过滤器。

@FilterDef属性:
name:
defaultCondition:默认过滤条件。可不写。
parameters:指定过滤器中sql表达式支持的参数。

@FilterDefs({
@FilterDef(name="effectiveDate"
    , parameters={@ParamDef(name="asOfDate" , type="date")}),
@FilterDef(name="category"
    , parameters={@ParamDef(name="catId" , type="int")})
})
@Entity
@Table(name="product_inf")
@Filter(name="effectiveDate"
    , condition=":asOfDate BETWEEN eff_start_date AND eff_end_date")

public class Product
{
    @Id @Column(name="product_id")
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    private Integer id;

    @Column(name="product_name")
    private String name;

    @Column(name="stock_number")
    private int stockNumber;
    @Column(name="eff_start_date")
    private Date effectiveStartDate;
    @Column(name="eff_end_date")
    private Date effectiveEndDate;

    @ManyToMany(targetEntity=Category.class)
    @JoinTable(name="product_category"
        , joinColumns=@JoinColumn(name="product_id")
        , inverseJoinColumns=@JoinColumn(name="category_id"))

    @Filters({
        @Filter(name="effectiveDate"
            , condition=":asOfDate BETWEEN eff_start_date and eff_end_date"),
        @Filter(name="category"
            , condition="category_id = :catId")
    })
    private Set<Category> categories
        = new HashSet<>();

系统默认不启动过滤器,必须通过session.enableFilteer(String filterName)才可以启用,而且一旦启动他将在整个session内有效。知道session调用disableFilter()方法。

session.enableFilter("effectiveDate")
            .setParameter("asOfDate", new Date());
        session.enableFilter("category")
            .setParameter("catId", 2);
        List list = session.createQuery("from Product as p").list();
        for (Object obj : list)
        {
            Product p = (Product)obj;
            System.out.println(p.getName());
            System.out.println("----" + p.getCategories()); 
        }

拦截器

通过Interceptor接口,可以从session中回调应用程序的特定方法。这种回调机制可以让应用程序在持久化对象被保存、删除、修改、加载之前,检查并修改其属性。
使用步骤:
1. 定义实现Interceptor接口的拦截器。最好继承EmptyInterceptor类。

public class MyInterceptor extends EmptyInterceptor
{

    private int updates;

    private int creates;


    public void onDelete(Object entity , Serializable id ,
        Object[] state , String[] propertyNames , Type[] types)
    {
        // do nothing
    }


    public boolean onFlushDirty(Object entity , Serializable id ,
        Object[] currentState, Object[] previousState,
        String[] propertyNames, Type[] types)
    {

        updates++;
        for ( int i = 0; i < propertyNames.length; i++ )
        {
            if ( "lastUpdateTimestamp".equals( propertyNames[i] ) )
            {
                currentState[i] = new Date();
                return true;
            }
        }
        return false;
    }


    public boolean onLoad(Object entity , Serializable id ,
        Object[] state,String[] propertyNames,Type[] types)
    {
        for ( int i = 0; i < propertyNames.length ; i++ )
        {
            if ( "name".equals( propertyNames[i] ) )
            {
                System.out.println( state[i] );
                return true;
            }
        }
        return false;
    }


    public boolean onSave(Object entity , Serializable id ,
        Object[] state,String[] propertyNames,Type[] types)
    {
        creates++;
        for ( int i = 0; i < propertyNames.length; i++ )
        {
            if ("createTimestamp".equals( propertyNames[i]))
            {
                state[i] = new Date();
                return true;
            }
        }
        return false;
    }


    public void postFlush(Iterator entities)
    {
        System.out.println("´创建的次数"
            + creates + ", 更新的次数" + updates);
    }


    public void preFlush(Iterator entities)
    {
        // do nothing
    }


    public void beforeTransactionCompletion(Transaction tx)
    {
        System.out.println("事务即将开始");
    }


    public void afterTransactionCompletion(Transaction tx)
    {
        System.out.println("事务已将结束");
    }
  1. 通过sessionFactory.openSession(Interceptor in)启动局部拦截器。或Configuration.setInterceptor(Interceptor in)来设置全局拦截器。
static Configuration cfg = new Configuration()
        .configure()
        .setInterceptor(new MyInterceptor());

事件系统

可作为拦截器的补充或代替拦截器。
Session接口的每个方法都有对应的事件。比如LoadEvent,FlushEvent等。当session调用某个方法时,session会生成对应的事件。并激活对应的事件监听器。
可以在系统中实现并注册LoadEventListener监听器,负责所有的调用session.load()方法的请求。
使用事件系统的步骤:
1. 实现自己的事件监听器类。一般采用继承系统默认的监听器,扩展特定的方法。
2. 注册自定义事件监听器,代替系统默认的事件监听器。

public class MySaveListener extends DefaultSaveEventListener
{
    public Serializable performSaveOrUpdate(SaveOrUpdateEvent event)
    {
        System.out.println(event.getObject());
        return super.performSaveOrUpdate(event);
    }
}
public class MyLoadListener extends DefaultLoadEventListener
{
    public void onLoad(LoadEvent event,
        LoadEventListener.LoadType loadType)
        throws HibernateException
    {
        System.out.println(event.getEntityClassName()
            + "==========" + event.getEntityId());
        super.onLoad(event, loadType);
    }
}

hibernate提供了一个EventListenerRegistry接口来注册事件监听器。一共有三个方法:
appendListener();加到系统默认的事件监听器后面
prependListener():加到系统默认的事件监听器前面
setListener():替换系统默认的事件监听器

static ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder()
        .applySettings(cfg.getProperties()).build();
    static SessionFactory sf = cfg.buildSessionFactory(serviceRegistry);
    static{
        EventListenerRegistry elr = ((SessionFactoryImpl)sf)
            .getServiceRegistry().getService(EventListenerRegistry.class);
        elr.setListeners(EventType.SAVE, MySaveListener.class);
        elr.setListeners(EventType.LOAD, MyLoadListener.class);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
完整全套资源下载地址:https://download.csdn.net/download/qq_27595745/66241619 【完整课程列表】 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 01 JavaEE介绍和环境配置(共30页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 02 JDBC(共45页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 03 JSP基础编程(共46页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 04 JSP内置对象(共48页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 05 JSP和JavaBean(共31页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 06 Servlet基础编程(共25页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 07 Servlet高级编程(共30页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 08 EL和JSTL(共40页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 09 Ajax(共26页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 10 MVC和Struts 基本原理(共26页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 11 Struts标签和错误处理(共38页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 12 Struts2基础开发(共30页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 13 Hibernate基础编程(共26页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 14 Hibernate高级编程(共27页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 15 Spring基础编程(共24页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 16 Struts、Spring、Hibernate的整合(共22页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 17 EJB3.0_会话Bean(共29页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 18 EJB3.0_实体Bean(共25页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 19 log4j和Ant(共25页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 20 DOM和SAX(共33页).ppt 推荐完整精品J2EE课件 JavaEE程序设计与应用开发教程 上机习题(共5页).ppt
1. 在Tomcat中快速上手 1.1. 开始Hibernate之旅 1.2. 第一个持久化类 1.3. 映射cat 1.4. 与Cat同乐 1.5. 结语 2. 架构(Architecture) 2.1. 概况(Overview) 2.2. 实例状态 2.3. JMX整合 2.4. 对JCA的支持 3. 配置 3.1. 可编程的配置方式 3.2. 获得SessionFactory 3.3. JDBC连接 3.4. 可选的配置属性 3.4.1. SQL方言 3.4.2. 外连接抓取(Outer Join Fetching) 3.4.3. 二进制流 (Binary Streams) 3.4.4. 二级缓存与查询缓存 3.4.5. 查询语言中的替换 3.4.6. Hibernate的统计(statistics)机制 3.5. 日志 3.6. 实现NamingStrategy 3.7. XML配置文件 3.8. J2EE应用程序服务器的集成 3.8.1. 事务策略配置 3.8.2. JNDI绑定的SessionFactory 3.8.3. JTA和Session的自动绑定 3.8.4. JMX部署 4. 持久化类(Persistent Classes) 4.1. 一个简单的POJO例子 4.1.1. 为持久化字段声明访问器(accessors)和是否可变的标志(mutators) 4.1.2. 实现一个默认的(即无参数的)构造方法(constructor) 4.1.3. 提供一个标识属性(identifier property)(可选) 4.1.4. 使用非final的类 (可选) 4.2. 实现继承(Inheritance) 4.3. 实现equals()和hashCode() 4.4. 动态模型(Dynamic models) 5. 对象/关系数据库映射基础(Basic O/R Mapping) 5.1. 映射定义(Mapping declaration) 5.1.1. Doctype 5.1.2. hibernate-mapping 5.1.3. class 5.1.4. id 5.1.4.1. Generator 5.1.4.2. 高/低位算法(Hi/Lo Algorithm) 5.1.4.3. UUID算法(UUID Algorithm ) 5.1.4.4. 标识字段和序列(Identity columns and Sequences) 5.1.4.5. 程序分配的标识符(Assigned Identifiers) 5.1.4.6. 触发器实现的主键生成器(Primary keys assigned by triggers) 5.1.5. composite-id 5.1.6. 鉴别器(discriminator) 5.1.7. 版本(version)(可选) 5.1.8. timestamp (optional) 5.1.9. property 5.1.10. 多对一(many-to-one) 5.1.11. 一对一 5.1.12. 组件(component), 动态组件(dynamic-component) 5.1.13. properties 5.1.14. 子类(subclass) 5.1.15. 连接的子类(joined-subclass) 5.1.16. 联合子类(union-subclass) 5.1.17. 连接(join) 5.1.18. 键(key) 5.1.19. 字段和规则元素(column and formula elements) 5.1.20. 引用(import) 5.1.21. any 5.2. Hibernate 的类型 5.2.1. 实体(Entities)和值(values) 5.2.2. 基本值类型 5.2.3. 自定义值类型 5.3. SQL中引号包围的标识符 5.4. 其他元数据(Metadata) 5.4.1. 使用 XDoclet 标记 5.4.2. 使用 JDK 5.0 的注解(Annotation) 6. 集合类(Collections)映射 6.1. 持久化集合类(Persistent collections) 6.2. 集合映射( Collection mappings ) 6.2.1. 集合外键(Collection foreign keys) 6.2.2. 集合元素(Collection elements) 6.2.3. 索引集合类(Indexed collections) 6.2.4. 值集合于多对多关联(Collections of values and many-to-many associations) 6.2.5. 一对多关联(One-to-many Associations) 6.3. 高级集合映射(Advanced collection mappings) 6.3.1. 有序集合(Sorted collections) 6.3.2. 双向关联(Bidirectional associations) 6.3.3. 三重关联(Ternary associations) 6.3.4. 使用<idbag> 6.4. 集合例子(Collection example) 7. 关联关系映射 7.1. 介绍 7.2. 单向关联(Unidirectional associations) 7.2.1. 多对一(many to one) 7.2.2. 一对一(one to one) 7.2.3. 一对多(one to many) 7.3. 使用连接表的单向关联(Unidirectional associations with join tables) 7.3.1. 一对多(one to many) 7.3.2. 多对一(many to one) 7.3.3. 一对一(one to one) 7.3.4. 多对多(many to many) 7.4. 双向关联(Bidirectional associations) 7.4.1. 一对多(one to many) / 多对一(many to one) 7.4.2. 一对一(one to one) 7.5. 使用连接表的双向关联(Bidirectional associations with join tables) 7.5.1. 一对多(one to many) /多对一( many to one) 7.5.2. 一对一(one to one) 7.5.3. 多对多(many to many) 8. 组件(Component)映射 8.1. 依赖对象(Dependent objects) 8.2. 在集合中出现的依赖对象 8.3. 组件作为Map的索引(Components as Map indices ) 8.4. 组件作为联合标识符(Components as composite identifiers) 8.5. 动态组件 (Dynamic components) 9. 继承映射(Inheritance Mappings) 9.1. 三种策略 9.1.1. 每个类分层结构一张表(Table per class hierarchy) 9.1.2. 每个子类一张表(Table per subclass) 9.1.3. 每个子类一张表(Table per subclass),使用辨别标志(Discriminator) 9.1.4. 混合使用“每个类分层结构一张表”和“每个子类一张表” 9.1.5. 每个具体类一张表(Table per concrete class) 9.1.6. Table per concrete class, using implicit polymorphism 9.1.7. 隐式多态和其他继承映射混合使用 9.2. 限制 10. 与对象共事 10.1. Hibernate对象状态(object states) 10.2. 使对象持久化 10.3. 装载对象 10.4. 查询 10.4.1. 执行查询 10.4.1.1. 迭代式获取结果(Iterating results) 10.4.1.2. 返回元组(tuples)的查询 10.4.1.3. 标量(Scalar)结果 10.4.1.4. 绑定参数 10.4.1.5. 分页 10.4.1.6. 可滚动遍历(Scrollable iteration) 10.4.1.7. 外置命名查询(Externalizing named queries) 10.4.2. 过滤集合 10.4.3. 条件查询(Criteria queries) 10.4.4. 使用原生SQL的查询 10.5. 修改持久对象 10.6. 修改脱管(Detached)对象 10.7. 自动状态检测 10.8. 删除持久对象 10.9. 在两个不同数据库间复制对象 10.10. Session刷出(flush) 10.11. 传播性持久化(transitive persistence) 10.12. 使用元数据 11. 事务和并发 11.1. Session和事务范围(transaction scopes) 11.1.1. 操作单元(Unit of work) 11.1.2. 应用程序事务(Application transactions) 11.1.3. 关注对象标识(Considering object identity) 11.1.4. 常见问题 11.2. 数据库事务声明 11.2.1. 非托管环境 11.2.2. 使用JTA 11.2.3. 异常处理 11.3. 乐观并发控制(Optimistic concurrency control) 11.3.1. 应用程序级别的版本检查(Application version checking) 11.3.2. 长生命周期session和自动版本化 11.3.3. 脱管对象(deatched object)和自动版本化 11.3.4. 定制自动版本化行为 11.4. 悲观锁定(Pessimistic Locking) 12. 拦截器与事件(Interceptors and events) 12.1. 拦截器(Interceptors) 12.2. 事件系统(Event system) 12.3. Hibernate的声明式安全机制 13. 批量处理(Batch processing) 13.1. 批量插入(Batch inserts) 13.2. 批量更新(Batch updates) 13.3. 大批量更新/删除(Bulk update/delete) 14. HQL: Hibernate查询语言 14.1. 大小写敏感性问题 14.2. from子句 14.3. 关联(Association)与连接(Join) 14.4. select子句 14.5. 聚集函数 14.6. 多态查询 14.7. where子句 14.8. 表达式 14.9. order by子句 14.10. group by子句 14.11. 子查询 14.12. HQL示例 14.13. 批量的UPDATE & DELETE语句 14.14. 小技巧 & 小窍门 15. 条件查询(Criteria Queries) 15.1. 创建一个Criteria 实例 15.2. 限制结果集内容 15.3. 结果集排序 15.4. 关联 15.5. 动态关联抓取 15.6. 查询示例 15.7. 投影(Projections)、聚合(aggregation)和分组(grouping) 15.8. 离线(detached)查询和子查询 16. Native SQL查询 16.1. 创建一个基于SQL的Query 16.2. 别名和属性引用 16.3. 命名SQL查询 16.3.1. 使用return-property来明确地指定字段/别名 16.3.2. 使用存储过程来查询 16.3.2.1. 使用存储过程的规则和限制 16.4. 定制SQL用来create,update和delete 16.5. 定制装载SQL 17. 过滤数据 17.1. Hibernate 过滤器(filters) 18. XML映射 18.1. 用XML数据进行工作 18.1.1. 指定同时映射XML和类 18.1.2. 只定义XML映射 18.2. XML映射元数据 18.3. 操作XML数据 19. 提升性能 19.1. 抓取策略(Fetching strategies) 19.1.1. 调整抓取策略(Tuning fetch strategies) 19.1.2. 单端关联代理(Single-ended association proxies) 19.1.3. 实例化集合和代理(Initializing collections and proxies) 19.1.4. 使用批量抓取(Using batch fetching) 19.1.5. 使用子查询抓取(Using subselect fetching) 19.1.6. 使用延迟属性抓取(Using lazy property fetching) 19.2. 二级缓存(The Second Level Cache) 19.2.1. 缓存映射(Cache mappings) 19.2.2. 策略:只读缓存(Strategy: read only) 19.2.3. 策略:读/写缓存(Strategy: read/write) 19.2.4. 策略:非严格读/写缓存(Strategy: nonstrict read/write) 19.2.5. 策略:事务缓存(transactional) 19.3. 管理缓存(Managing the caches) 19.4. 查询缓存(The Query Cache) 19.5. 理解集合性能(Understanding Collection performance) 19.5.1. 分类(Taxonomy) 19.5.2. Lists, maps 和sets用于更新效率最高 19.5.3. Bag和list是反向集合类中效率最高的 19.5.4. 一次性删除(One shot delete) 19.6. 监测性能(Monitoring performance) 19.6.1. 监测SessionFactory 19.6.2. 数据记录(Metrics) 20. 工具箱指南 20.1. Schema自动生成(Automatic schema generation) 20.1.1. 对schema定制化(Customizing the schema) 20.1.2. 运行该工具 20.1.3. 属性(Properties) 20.1.4. 使用Ant(Using Ant) 20.1.5. 对schema的增量更新(Incremental schema updates) 20.1.6. 用Ant来增量更新schema(Using Ant for incremental schema updates) 21. 示例:父子关系(Parent Child Relationships) 21.1. 关于collections 21.2. 双向的一对多关系(Bidirectional one-to-many) 21.3. 级联生命周期(Cascading lifecycle) 21.4. 级联与未保存值(Cascades and unsaved-value) 21.5. 结论 22. 示例:Weblog 应用程序 22.1. 持久化类 22.2. Hibernate 映射 22.3. Hibernate 代码 23. 示例:复杂映射实例 23.1. Employer(雇主)/Employee(雇员) 23.2. Author(作家)/Work(作品) 23.3. Customer(客户)/Order(订单)/Product(产品) 23.4. 杂例 23.4.1. "Typed" one-to-one association 23.4.2. Composite key example 23.4.3. Content based discrimination 23.4.4. Associations on alternate keys 24. 最佳实践(Best Practices)

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值