( 转)Hibernate常用API

http://blog.csdn.net/yerenyuan_pku/article/details/65103203

可在度娘上摘抄如下文字:

Hibernate的核心类和接口一共有6个,分别为:Session、SessionFactory、Transaction、Query、Criteria和Configuration。这6个核心类和接口在任何开发中都会用到。

还记得上一篇文章讲的是《Hibernate的配置详解》,本文继续在其基础之上讲解Hibernate常用的API。

Configuration

Configuration类主要是用于加载Hibernate的核心配置文件。 
为了和之前写的单元测试类——HibernateTest1.java相区分,我们这儿在cn.itheima.test包下再创建一个单元测试类——HibernateTest2.java。像之前写的这样的代码:

public class HibernateTest2 {

    @Test
    public void test1() { // 创建Configuration来加载配置文件 Configuration config = new Configuration().configure(); ....... } }

 

主要是加载src目录下的hibernate.cfg.xml配置文件。 
如果现在有人标新立异,他不是将Hibernate的核心配置文件命名为hibernate.cfg.xml,而是将其命名为比如说是my.xml,假设该文件同样是位于src目录下。那么应该像这样加载该文件:

public class HibernateTest2 {

    @Test
    public void test1() { // 创建Configuration来加载配置文件 Configuration config = new Configuration().configure("my.xml"); // 加载指定名称的配置文件 ....... } }

 

可归纳为:

Configuration config=new Configuration().config(核心配置文件名称); // 加载指定名称的配置文件

 

但我们又何必这么写昵?你说是不是? 
由于我们将实体类(Customer.java)的映射配置文件配置在Hibernate的核心配置文件中:

<hibernate-configuration>
    <session-factory>
        ......
        <!-- 配置hibernate的映射文件所在的位置 --> <mapping resource="cn/itheima/domain/Customer.hbm.xml" /> </session-factory> </hibernate-configuration>

 

所以在编写程序代码的时候,勿须手动加载映射配置文件——Customer.hbm.xml。映射配置文件一般情况下是放置在实体类所在包下的,但是不这样做也是可以的,因为可以指定路径。所以即使在Hibernate的核心配置文件中没有映射文件的配置,也是可以手动加载映射配置文件的。

public class HibernateTest2 {

    // 测试手动加载映射配置文件
    @Test
    public void test1() { // 1.创建Configuration来加载配置文件 Configuration config = new Configuration().configure(); // 手动加载映射 config.addResource("cn/itheima/domain/Customer.hbm.xml"); // 直接加载映射配置文件 // 2.得到SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(); // 3.得到Session Session session = sessionFactory.openSession(); // 开启事务 session.beginTransaction(); Customer c = session.get(Customer.class, 1); System.out.println(c); // 事务提交 session.getTransaction().commit(); // 关闭Session session.close(); // 关闭SessionFactory sessionFactory.close(); } }

 

当然了,我们还可以这样做:

public class HibernateTest2 {

    // 测试手动加载映射配置文件
    @Test
    public void test1() { // 1.创建Configuration来加载配置文件 Configuration config = new Configuration().configure(); // 手动加载映射 config.addClass(Customer.class); // 这种方式它会直接在实体类所在包下查找规范的映射配置文件 // 2.得到SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(); // 3.得到Session Session session = sessionFactory.openSession(); // 开启事务 session.beginTransaction(); Customer c = session.get(Customer.class, 1); System.out.println(c); // 事务提交 session.getTransaction().commit(); // 关闭Session session.close(); // 关闭SessionFactory sessionFactory.close(); } }

 

只是这种情况下,Customer.hbm.xml映射配置文件须放置在实体类所在包下。 
我们之前也说过对于Hibernate的核心配置文件它有两种方式:

  1. hibernate.cfg.xml
  2. hibernate.properties

假如Hibernate的核心配置文件采用的是hibernate.properties这种方式,那么如何加载该配置文件昵?

public class HibernateTest2 {

    @Test
    public void test1() { Configuration config = new Configuration(); ....... } }

 

结论:

Configuration config=new Configuration(); // 主要加载的是src目录下的hibernate.properties配置文件

 

那么问题来了,我们是在hibernate.cfg.xml文件中有(映射)了xxx.hbm.xml文件的位置。但如果我们使用的是hibernate.properties这种核心配置文件,那么它又如何加载映射配置文件昵?不用我说,大家应该都知道了。

SessionFactory

首先SessionFactory它的获取是通过Configuration得到:

// 1.创建Configuration来加载配置文件
Configuration config = new Configuration().configure(); // 2.得到SessionFactory SessionFactory sessionFactory = config.buildSessionFactory();

 

 

可在度娘上摘抄如下有关SessionFactory的文字:

SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。

下面我们来着重分析以上这段话,我是从这几句话入手的。

它充当数据存储源的代理,并负责创建Session对象。

我们通过查看Hibernate的帮助文档,可发现通过SessionFactory可以得到Session有两种方式:

  1. 通过SessionFactory获得Session方式一: 
    这里写图片描述
    注意:这是从连接池中获取一个连接。
  2. 通过SessionFactory获得Session方式二: 
    这里写图片描述
    注意:这是获取一个与线程绑定的Session(即线程安全的Session)。

需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够

我的理解——SessionFactory它不是轻量级的,所以不要频繁创建关闭它。在一个项目中有一个SessionFactory就可以了,通过SessionFactory来获取Session进行操作。那么问题来了,怎样可以保证在一个项目中所使用的SessionFactory是同一个哪? 
可在cn.itheima.utils包下创建一个工具类——HibernateUtils.java,其代码为:

public class HibernateUtils {

    private static Configuration config;
    private static SessionFactory sessionFactory; static { config = new Configuration().configure(); sessionFactory = config.buildSessionFactory(); } public static Session openSession() { return sessionFactory.openSession(); } }

 

好了,来测试HibernateUtils工具类的使用吧!

public class HibernateTest2 {

    // 测试HibernateUtils工具使用
    @Test
    public void test2() { // 得到Session Session session = HibernateUtils.openSession(); // 开启事务 session.beginTransaction(); Customer c = session.get(Customer.class, 1); System.out.println(c); // 事务提交 session.getTransaction().commit(); // 关闭Session session.close(); // 注意:SessionFactory不要关闭,它开启就别关了,除非说你的项目结束了,否则,我们就不关闭它 } }

 

SessionFactory内部还维护了一个连接池,如果我们要想使用c3p0连接池,应该怎样做昵?也即在Hibernate中如何使用c3p0连接池?

  1. 我们要导入c3p0的相关jar包。 
    在lib/options下有关于c3p0连接池所需jar包,如下: 
  2. 在hibernate.cfg.xml文件中配置c3p0连接池。

    <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> <!-- C3P0连接池的配置 --> <property name="hibernate.c3p0.max_size">20</property> <!-- 最大连接数 --> <property name="hibernate.c3p0.min_size">5</property> <!-- 最小连接数 --> <property name="hibernate.c3p0.timeout">120</property> <!-- 超时时间 --> <property name="hibernate.c3p0.idle_test_period">3000</property> <!-- 空闲连接(等待)时间,以秒为单位 -->

    注意:有些童鞋可能忘记了这样的配置:

    <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
  3. 这当然是不可取的,以上配置是在设置连接池提供者,如没设置,默认为org.hibernate.connection.DriverManagerConnectionProvider,它会帮助我们从Hibernate本身维护的连接池里面获取连接。但是现在我们要用C3P0连接池,所以这样的设置是必不可少的,这样的话,Hibernate才知道你现在要用的是C3P0连接池!

当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。

我觉得这是要涉及分布式数据库的节奏,对此我也是小白。只是知道怎么配置而已,大概类似于一下配置吧!

<hibernate-configuration>
    <session-factory> ...... </session-factory> <session-factory name="xxx"> ...... </session-factory> </hibernate-configuration>

 

Session

从度娘摘抄如下:

Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句)。但需要注意的是Session对象是非线程安全的。

那么问题来了,我们如何解决session的安全问题?我们只需要在方法内部来使用Session就可以。 
那么问题又来了,Session如何获取到昵?在讲SessionFactory接口时,我们就介绍了通过SessionFactory获得Session的两种方式,虽然这两种方式都可以获取到一个Session对象,那么这两种方式有什么区别呢?

  • SessionFactory.openSession();:相当于直接通过SessionFactory创建一个新的Session,使用完成后要手动调用close()方法来关闭。
  • SessionFactory.getCurrentSession();:获取一个与线程绑定的Session,当我们提交事务或事务回滚后会自动关闭。

Session的常用方法

  • save():保存对象
  • update ():修改操作
  • delete():删除
  • get()/load():根据id进行查询
  • avenOrUpdate():执行save或update操作
  • createQuery():获取一个Query对象
  • CreateSQLQUery():获取一个可以操作SQL的SQLQuery对象
  • createCriteria():取一个Criteria对象,它可以完成条件查询

以上的许多方法,我们都已接触过,不过后面随着我们学习的精进,还会对他们越来越熟悉。

Transaction

Transaction接口主要用于管理事务,它是Hibernate的事务接口,对底层的事务进行了封装。使用它可以进行事务操作。例如:

  • 事务提交:commit()
  • 事务回滚:rollback()

问题一:如何获取一个Transaction对象昵?可通过如下代码获得:

Transaction transaction = session.beginTransaction();

 

问题二:如果在程序中没有开启事务,是否存在事务?存在事务,默认session的每一个操作就会开启一个事务。并且默认情况下事务是不会自动提交的。相当于在Hibernate的核心配置文件中又如下配置:

<!-- 用于设置事务提交方式,默认是不自动提交的 -->
<property name="hibernate.connection.autocommit">false</property>

 

如果我们将其修改为:

<property name="hibernate.connection.autocommit">true</property>

 

则此时事务就会自动提交。

Query

从度娘上可摘抄到这样的文字:

Query接口让你方便地对数据库及持久对象进行查询,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作。

我们主要通过Query完成查询操作。通过Query即可以执行hql语句,如下:

Query query = session.createQuery("hql语句");

 

又可以执行本地sql语句:

SQLQuery sqlQuery = session.createSQLQuery("本地sql语句");

 

注意:SQLQuery是Query的子类。

查询所有操作——使用HQL

为了和之前写的单元测试类——HibernateTest1.java和HibernateTest2.java相区分,我们这儿在cn.itheima.test包下准备再创建一个单元测试类——HibernateTest3.java。 
使用HQL语句完成查询所有客户的操作,代码如下:

public class HibernateTest3 {

    // 使用hql完成查询所有操作
    @Test
    public void test1() { Session session = HibernateUtils.openSession(); Query query = session.createQuery("from Customer"); // from后面是类名 List<Customer> list = query.list(); System.out.println(list); session.close(); } }

注意:from后面是类名。

分页查询

在执行分页查询时,我们试着向t_customer表中插入100条记录。代码如下:

public class HibernateTest3 {

    // 向表中插入100条记录
    @Test
    public void test2() { Session session = HibernateUtils.openSession(); // 不要忘记开事务 session.beginTransaction(); for (int i = 0; i < 100; i++) { Customer c = new Customer(); c.setName("姓名" + i); c.setSex("男"); c.setAddress("北京"); session.save(c); } session.getTransaction().commit(); session.close(); } }

 

接下来,就来分页查询,要求:一页显示10条,但我们要得到第二页的数据。

public class HibernateTest3 {

    // 分页查询
    // 一页显示10条,要得到第二页数据
    @Test
    public void test3() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 一页显示10条,要得到第二页数据 Query query = session.createQuery("from Customer"); query.setFirstResult(10); // 从第几条开始,即开始位置,从0开始计数 query.setMaxResults(10); // 本次查询结果回显的条数 List<Customer> list = query.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

查询指定列信息

如果想如下这样子查询指定列的信息:

public class HibernateTest3 {

    // 查询指定列信息
    @Test
    public void test4() { Session session = HibernateUtils.openSession(); session.beginTransaction(); Query query = session.createQuery("select name,address from Customer"); // 这时我们得到的不再是Customer对象,而是Object[] List<Object[]> list = query.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

可以发现select name,address from Customer得到的是List<Object[]>结果,我们可不可以得到List<Customer>这样的结果昵?我们要想得到这个结果,可以使用Hibernate中的投影查询。我们只须在Customer类中提供name与address作为参数的构造方法就可以了,注意无参数构造也要有。而且HQL语句要写成select new Customer(name,address) from Customer

public class HibernateTest3 {

    // 查询指定列信息
    @Test
    public void test4() { Session session = HibernateUtils.openSession(); session.beginTransaction(); Query query = session.createQuery("select new Customer(name,address) from Customer"); List<Customer> list = query.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

条件查询

条件查询,可以使用where关键字。 
例,需求:查询name=姓名0的客户。 
首先通过无名称参数来完成这个需求。

public class HibernateTest3 {

    // 条件查询,可以使用where关键字
    @Test
    public void test5() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 查询name=姓名0的信息 Query query = session.createQuery("from Customer where name=?"); // 这是一种无名称参数 // 要对参数进行赋值 query.setParameter(0, "姓名0"); List<Customer> list = query.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

虽然我们可以查询出来,但我们有没有想过name=姓名0的客户即使查出来也只有一个,我们有必要把它放在List集合中嘛?如果查询结果可以保证就是唯一 的,我们可以使用query. uniqueResult()来得到一个单独对象。

public class HibernateTest3 {

    // 条件查询,可以使用where关键字
    @Test
    public void test5() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 查询name=姓名0的信息 Query query = session.createQuery("from Customer where name=?"); // 这是一种无名称参数 // 要对参数进行赋值 query.setParameter(0, "姓名0"); // 如果能保证结果就是唯一的,那么可以使用另外一种方法 Customer customer = (Customer) query.uniqueResult(); System.out.println(customer); session.getTransaction().commit(); session.close(); } }

 

然后再通过有名称参数来完成这个需求。

public class HibernateTest3 {

    // 条件查询,可以使用where关键字
    @Test
    public void test5() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 查询name=姓名0的信息 Query query = session.createQuery("from Customer where name=:myname"); // 这是一种有名称参数 // 对有名称参数进行赋值 query.setParameter("myname", "姓名0"); // 如果能保证结果就是唯一的,那么可以使用另外一种方法 Customer customer = (Customer) query.uniqueResult(); System.out.println(customer); session.getTransaction().commit(); session.close(); } }

 

执行本地SQL

要想执行本地sql,可以这样子做:

SQLQuery sqlQuery=session.createSqlQuery(String sql);

 

需求一:执行本地sql,查询全部客户。 
我想初次写代码完成这个需求,许多人都会这么写吧!

public class HibernateTest3 {

    // 执行本地sql,查询全部
    @Test
    public void test6() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 执行 select * from t_customer; SQLQuery sqlQuery = session.createSQLQuery("select * from t_customer"); List<Object[]> list = sqlQuery.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

可以发现select * from t_customer得到的是List<Object[]>结果,我们可不可以得到List<Customer>这样的结果昵?可以,代码如下:

public class HibernateTest3 {

    // 执行本地sql,查询全部
    @Test
    public void test6() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 执行 select * from t_customer; SQLQuery sqlQuery = session.createSQLQuery("select * from t_customer"); // 想要将结果封装到Customer对象中 sqlQuery.addEntity(Customer.class); List<Customer> list = sqlQuery.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

需求二:执行本地sql,条件查询。例如查询name=姓名1的客户。

public class HibernateTest3 {

    // 执行本地sql,条件查询
    @Test
    public void test7() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 执行 select * from t_customer where name=?; SQLQuery sqlQuery = session.createSQLQuery("select * from t_customer where name=?"); // 对参数进行赋值 sqlQuery.setParameter(0, "姓名1"); // 想要将结果封装到Customer对象中 sqlQuery.addEntity(Customer.class); /* List<Customer> list = sqlQuery.list(); System.out.println(list); */ Customer customer = (Customer) sqlQuery.uniqueResult(); System.out.println(customer); session.getTransaction().commit(); session.close(); } }

 

Criteria

根据度娘所得:

Criteria接口与Query接口非常类似,允许创建并执行面向对象的标准化查询。值得注意的是Criteria接口也是轻量级的,它不能在Session之外使用。

首先我要想使用Criteria,必须得到Criteria。可这么做:

Criteria criteria = session.createCriteria(Xxx.class);

 

需求一:查询所有客户。

public class HibernateTest3 {

    // 测试Criteria
    @Test
    public void test8() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 得到Criteria Criteria criteria = session.createCriteria(Customer.class); // 查询所有 List<Customer> list = criteria.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

需求二:分页查询。 
分页查询操作与query的方法一样。通者自通。 
需求三:多条件查询。例如查询name=”姓名1”并且address=”上海”的客户。

public class HibernateTest3 {

    // 测试Criteria
    @Test
    public void test8() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 得到Criteria Criteria criteria = session.createCriteria(Customer.class); // 多条件查询 // 1.查询name='姓名1' criteria.add(Restrictions.eq("name", "姓名1")); // where name="姓名1"; // 2.查询address='上海' criteria.add(Restrictions.eq("address", "上海")); // where name="姓名1" and address="上海" Customer customer = (Customer) criteria.uniqueResult(); session.getTransaction().commit(); session.close(); } }

 

需求四:多条件查询。例如查询name=’姓名1’或者address=’上海’的客户。

public class HibernateTest3 {

    // 测试Criteria
    @Test
    public void test8() { Session session = HibernateUtils.openSession(); session.beginTransaction(); // 得到Criteria Criteria criteria = session.createCriteria(Customer.class); // 多条件查询 // 查询name='姓名1'或者address='上海' criteria.add(Restrictions.or(Restrictions.eq("name", "姓名1"),Restrictions.eq("address", "上海"))); List<Customer> list = criteria.list(); System.out.println(list); session.getTransaction().commit(); session.close(); } }

 

总结:我们使用Criteria可以更加面向对象地去操作,它非常适合进行多条件组合查询。但感觉没什么鸟用!

转载于:https://www.cnblogs.com/telwanggs/p/6963683.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HIBERNATE - 符合Java习惯的关系数据库持久化 Hibernate参考文档 3.2 -------------------------------------------------------------------------------- 目录 前言 1. 翻译说明 2. 版权声明 1. Hibernate入门 1.1. 前言 1.2. 第一部分 - 第一个Hibernate应用程序 1.2.1. 第一个class 1.2.2. 映射文件 1.2.3. Hibernate配置 1.2.4. 用Ant构建 1.2.5. 启动和辅助类 1.2.6. 加载并存储对象 1.3. 第二部分 - 关联映射 1.3.1. 映射Person类 1.3.2. 单向Set-based的关联 1.3.3. 使关联工作 1.3.4. 值类型的集合 1.3.5. 双向关联 1.3.6. 使双向连起来 1.4. 第三部分 - EventManager web应用程序 1.4.1. 编写基本的servlet 1.4.2. 处理与渲染 1.4.3. 部署与测试 1.5. 总结 2. 体系结构(Architecture) 2.1. 概况(Overview) 2.2. 实例状态 2.3. JMX整合 2.4. 对JCA的支持 2.5. 上下文相关的(Contextual)Session 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环境下使用Current Session context (当前session上下文)管理 3.8.4. JMX部署 4. 持久化类(Persistent Classes) 4.1. 一个简单的POJO例子 4.1.1. 实现一个默认的(即无参数的)构造方法(constructor) 4.1.2. 提供一个标识属性(identifier property)(可选) 4.1.3. 使用非final的类 (可选) 4.1.4. 为持久化字段声明访问器(accessors)和是否可变的标志(mutators)(可选) 4.2. 实现继承(Inheritance) 4.3. 实现equals()和hashCode() 4.4. 动态模型(Dynamic models) 4.5. 元组片断映射(Tuplizers) 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.5. composite-id 5.1.6. 鉴别器(discriminator) 5.1.7. 版本(version)(可选) 5.1.8. timestamp (可选) 5.1.9. property 5.1.10. 多对一(many-to-one) 5.1.11. 一对一 5.1.12. 自然ID(natural-id) 5.1.13. 组件(component), 动态组件(dynamic-component) 5.1.14. properties 5.1.15. 子类(subclass) 5.1.16. 连接的子类(joined-subclass) 5.1.17. 联合子类(union-subclass) 5.1.18. 连接(join) 5.1.19. 键(key) 5.1.20. 字段和规则元素(column and formula elements) 5.1.21. 引用(import) 5.1.22. any 5.2. Hibernate 的类型 5.2.1. 实体(Entities)和值(values) 5.2.2. 基本值类型 5.2.3. 自定义值类型 5.3. 多次映射同一个类 5.4. SQL中引号包围的标识符 5.5. 其他元数据(Metadata) 5.5.1. 使用 XDoclet 标记 5.5.2. 使用 JDK 5.0 的注解(Annotation) 5.6. 数据库生成属性(Generated Properties) 5.7. 辅助数据库对象(Auxiliary Database Objects) 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. 双向关联,涉及有序集合类 6.3.4. 三重关联(Ternary associations) 6.3.5. 使用<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) 7.6. 更复杂的关联映射 8. 组件(Component)映射 8.1. 依赖对象(Dependent objects) 8.2. 在集合中出现的依赖对象 (Collections of dependent objects) 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.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 scope) 11.1.1. 操作单元(Unit of work) 11.1.2. 长对话 11.1.3. 关注对象标识(Considering object identity) 11.1.4. 常见问题 11.2. 数据库事务声明 11.2.1. 非托管环境 11.2.2. 使用JTA 11.2.3. 异常处理 11.2.4. 事务超时 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) 11.5. 连接释放模式(Connection Release Modes) 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. StatelessSession (无状态session)接口 13.4. DML(数据操作语言)风格的操作(DML-style operations) 14. HQL: Hibernate查询语言 14.1. 大小写敏感性问题 14.2. from子句 14.3. 关联(Association)与连接(Join) 14.4. join 语法的形式 14.5. select子句 14.6. 聚集函数 14.7. 多态查询 14.8. where子句 14.9. 表达式 14.10. order by子句 14.11. group by子句 14.12. 子查询 14.13. HQL示例 14.14. 批量的UPDATE和DELETE 14.15. 小技巧 & 小窍门 15. 条件查询(Criteria Queries) 15.1. 创建一个Criteria 实例 15.2. 限制结果集内容 15.3. 结果集排序 15.4. 关联 15.5. 动态关联抓取 15.6. 查询示例 15.7. 投影(Projections)、聚合(aggregation)和分组(grouping) 15.8. 离线(detached)查询和子查询 15.9. 根据自然标识查询(Queries by natural identifier) 16. Native SQL查询 16.1. 使用SQLQuery 16.1.1. 标量查询(Scalar queries) 16.1.2. 实体查询(Entity queries) 16.1.3. 处理关联和集合类(Handling associations and collections) 16.1.4. 返回多个实体(Returning multiple entities) 16.1.5. 返回非受管实体(Returning non-managed entities) 16.1.6. 处理继承(Handling inheritance) 16.1.7. 参数(Parameters) 16.2. 命名SQL查询 16.2.1. 使用return-property来明确地指定字段/别名 16.2.2. 使用存储过程来查询 16.3. 定制SQL用来create,update和delete 16.4. 定制装载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. 操作延迟加载的关联 19.1.2. 调整抓取策略(Tuning fetch strategies) 19.1.3. 单端关联代理(Single-ended association proxies) 19.1.4. 实例化集合和代理(Initializing collections and proxies) 19.1.5. 使用批量抓取(Using batch fetching) 19.1.6. 使用子查询抓取(Using subselect fetching) 19.1.7. 使用延迟属性抓取(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) 20.1.7. Schema 校验 20.1.8. 使用Ant进行schema校验 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. 共有组合键属性的多对多(Many-to-many with shared composite key attribute) 23.4.4. Content based discrimination 23.4.5. Associations on alternate keys 24. 最佳实践(Best Practices) 表格清单 1. Hibernate v3翻译团队 3.1. Hibernate JDBC属性 3.2. Hibernate数据源属性 3.3. Hibernate配置属性 3.4. Hibernate JDBC和连接(connection)属性 3.5. Hibernate缓存属性 3.6. Hibernate事务属性 3.7. 其他属性 3.8. Hibernate SQL方言 (hibernate.dialect) 3.9. Hibernate日志类别 3.10. JTA TransactionManagers 9.1. 继承映射特性(Features of inheritance mappings) 16.1. 别名注射(alias injection names) 19.1. 缓存策略提供商(Cache Providers) 19.2. 各种缓存提供商对缓存并发策略的支持情况(Cache Concurrency Strategy Support) 20.1. Summary 20.2. SchemaExport命令行选项 20.3. SchemaExport 连接属性 20.4. SchemaUpdate命令行选项 20.5. SchemaValidator命令行参数
依赖对象(Dependent objects) 组件(Component)是一个被包含的对象,在持久化的过程中,它被当作值类型,而并非一个实体的引用。在这篇文档中,组件这一术语指的是面向对象的合成概念(而并不是系统构架层次上的组件的概念)。举个例子, 你对人(Person)这个概念可以像下面这样来建模: public class Person { private java.util.Date birthday; private Name name; private String key; public String getKey() { return key; } private void setKey(String key) { this.key=key; } public java.util.Date getBirthday() { return birthday; } public void setBirthday(java.util.Date birthday) { this.birthday = birthday; } public Name getName() { return name; } public void setName(Name name) { this.name = name; } ...... ...... } public class Name { char initial; String first; String last; public String getFirst() { return first; } void setFirst(String first) { this.first = first; } public String getLast() { return last; } void setLast(String last) { this.last = last; } public char getInitial() { return initial; } void setInitial(char initial) { this.initial = initial; } } 在持久化的过程中,姓名(Name)可以作为人(Person)的一个组件。需要注意的是:你应该为姓名的持久化属性定义getter和setter方法,但是你不需要实现任何的接口或申明标识符字段。 以下是这个例子的Hibernate映射文件: <!-- class attribute optional --> 人员(Person)表中将包括pid, birthday, initial, first和 last等字段。 就像所有的值类型一样, 组件不支持共享引用。 换句话说,两个人可能重名,但是两个Person对象应该包含两个独立的Name对象,只不过这两个Name对象具有“同样”的值。 组件的值可以为空,其定义如下。 每当Hibernate重新加载一个包含组件的对象,如果该组件的所有字段为空,Hibernate将假定整个组件为空。 在大多数情况下,这样假定应该是没有问题的。 组件的属性可以是任意一种Hibernate类型(包括集合, 多对多关联, 以及其它组件等等)。嵌套组件不应该被当作一种特殊的应用(Nested components should not be
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值