Hibernate进阶知识点必备

hibernate.cfg.xml的常用的配置

  • hibernate.show_sql:是否把Hibernate运行时的SQL语句输出到控制台,编码阶段便于测试,为true的好

-hibernate.format_sql:输出到控制台的SQL语句是否进行排版,便于阅读。建议设置为true。它好我也好嘛。

  • hbm2ddl.auto:可以帮助由java代码生成数据库脚本,进而生成具具体的表结构。create | update | create_drop | validate

    • create: 每次都会创建一个新的表结构(慎用)
    • update: 更新变化的部分,会维持原有的测试数据的存在
    • create_drop: 如果有就删掉再重新生成(慎用)
    • validate: 验证表结构有无冲突,有冲突则不进行操作
  • hibernate.default_schema: 默认的数据库。在创建数据库表结构的时候会加上此前缀

  • hibernate.dialect:配置Hibernate数据库的方言,Hibernate可以针对特殊的数据库进行优化!

session的简介

先看一下,hibernate的执行流程吧。

  • 首先是Configuration(hibernate.cfg.xml)

  • 然后是SessionFactory(Beans.hbm.xml):创建和销毁都相当的耗费资源,通常一个系统内一个数据库只创建一个这样的对象

  • Session: 相当于传统的JDBC中的Connection(但是session与connection是多对一的关系。开发的时候尽量不要使用connection):

    -开启一个事务(Transaction)

    • 利用session进行CRUD操作
    • 事务提交(transaction。commit())
    • 关闭会话(session.close())
    • 关闭sessionFactory(如果需要的话,一般不需要)
  • 如何获取session对象:

    • openSession的方式:针对的是sessionFactory而言。
    • getCurrentSession的方式():需要在hibernate.cfg.xml中实现对name为hibernate.current_session_context_class的属性的配置。值为thread代表本地事务。jta 代表全局事务。
    • 这二者的区别:后者事务提交或者回滚后悔自动的关闭,前者需要手动的关闭;后者使用的是单例模式,即只是对同一个底层的session的操作,前者则是每次创建一个新的session进行操作。

Transaction的简单的叙述

Hibernate对数据库的操作都是封装在事务中的,并且默认是非自动提交的方式。所以,用Session保存对象时,如果不开启事务,并且手动的提交事务,对象并不会真正的保存到数据库中。

但是如果你想让Hibernate像JDBC那样自动的提交事务,必须调用session的对象的doWork()方法,获得JDBC的connection后,设置其为自动提交事务模式。

通常来说,不建议采用自动提交的方式。因为要实现session的doWork方法,里面是一个匿名的类,。

hbm.xml配置文件常用的设置

<hibernate-mapping
    schema="schemaName"
    catalog="catalogName"
    default-cascade="cascade_style"//级联风格
    default-access="field|property|ClassName"//访问策略
    default-lazy="true|false"//加载的策略
    package="packageName"
    />

<class
    name="ClassName"
    table="tableName"
    batch-size="N"//抓取策略,一次抓取多少数据
    where="condition"
    entity-name="EntityName"
    />

<id  // 表示此属性在数据库中是做为主键出现的
    name="propertyName"
    type="typeName"
    column="column_name"
    length="length"
    <generator class ="generatorClass" />
    />

你可能感兴趣的:(java,Hibernate,数据库)