hibernate常用配置

核心配置

  核心配置有两种方式进行配置
    1:属性文件的配置:hibernate.properties
    格式:key=value
      hibernate.connection.driver_class=com.mysql.jdbc.Driver
    注意:没有办法在核心配置文件中加载映射文件.(必须手动编码的方式进行加载.)

    2:XML格式文件配置:hibernate.cfg.xml
      格式:<property name="hibernate.connection.username">root</property>

  核心配置中
    1.必须的配置
      连接数据库4个基本参数:
        hibernate.connection.driver_class 连接数据库驱动程序
        hibernate.connection.url 连接数据库URL
        hibernate.connection.username 数据库用户名
        hibernate.connection.password 数据库密码

      Hibernate的方言:
        hibernate.dialect 操作数据库方言

    2.可选的配置
      hibernate.show_sql true 在控制台上输出SQL语句
      hibernate.format_sql true 格式化控制台输出的SQL语句
      hibernate.connection.autocommit true 事务是否自动提交
      hibernate.hbm2ddl.auto create/create-drop/update/validate
        create :每次执行的时候,创建一个新的表.(如果以前有该表,将该表删除重新创建.) 一般测试的时候的使用.
        create-drop :每次执行的时候,创建一个新的表,程序执行结束后将这个表,删除掉了. 一般测试的时候使用.
        update :如果数据库中没有表,创建一个新的表,如果有了,直接使用这个表.可以更新表的结构.
        validate :会使用原有的表.完成校验.校验映射文件与表中配置的字段是否一致.不一致会报错.

    3.映射的配置
      在XML格式配置文件中加载映射文件:
        <mapping resource="cn/itcast/hibernate3/demo1/Customer.hbm.xml" />

映射文件的配置
  ORM:对象关系映射(Java对象与数据库表的映射)
  配置类与表的映射
    name:类的全路径
    table:表的名称(可以省略的.若省略使用类的名称作为表名.)
    <class name="cn.yzu.hibernate3.demo1.Order" table=”orders”>

  配置普通属性与字段映射
    <property name="name" column="name" type="string" length=”20”/>
      type:三种写法
        Java类型 :java.lang.String
        Hibernate类型 :string
        SQL类型 :不能直接使用type属性,需要子标签<column>
          <column name="name" sql-type="varchar(20)"/>

  配置唯一标识与主键映射
    一个表中只有一个主键的形式:<id name=”id” column=”id”>

      主键:自然主键和代理主键

        自然主键:
          创建一个人员表.人员表中某条记录唯一确定.如人都有身份证号.我们可以使用身份证号作为主键.(身份证号本身就是人员的一个属性.作为主键.)

        代理主键:
          创建一个人员表.人员表中某条记录唯一确定.但是没有使用身份证号作为主键,新建字段(用新建的字段作为主键.只是一个标识作用.)

        尽量要Hibernate自己去维护主键,尽量使用代理主键,因为如果我们使用自然主键如身份证号,万一有一天自然主键要参与业务逻辑,比如身份证号要发生修改,那么会非常麻烦。
      主键的生成策略:
        increment :自动增长.适合 short int long...不是使用数据库的自动增长机制.使用Hibernate框架提供的自动增长方式.
            插入数据时,先发送一条语句:select max(id) from 表; 在最大值的基础上+1再插入数据.(存在多线程的问题)在集群下不能使用

        identity :自动增长.适合 short int long...采用数据库的自动增长机制.不适合于Oracle数据库
        sequence :序列.适用于 short int long ... 应用在Oracle上 
        uuid :适用于字符串类型的主键.采用随机的字符串作为主键.
        native :本地策略.底层数据库不同.自动选择适用identity 还是 sequence
        assigned :Hibernate框架不维护主键,主键由程序自动生成.
        foreign :主键的外来的.(应用在多表一对一的关系.)

    一个表对应多个主键形式:(复合主键)---了解即可,用的很少:<composite-id></composite-id>,例如:
          

                                    

  命名SQL(配置后,可在Java代码中通过直接获取配置的名字而获得数据库语句)

<query name="findAll">
  from Customer
</query>

<sql-query name="sqlFindAll">
  select * from customer
</sql-query>
posted @ 2016-12-12 21:15  凌晨。。。三点  阅读(782)  评论(0编辑  收藏  举报