Hibernate学习笔记(三)配置详解

配置文件详解

  1. 基本mysql连接配置:
<!-- property 元素用于配置Hibernate中的属性 键:值 -->
		<!-- hibernate.connection.driver_class : 连接数据库的驱动  -->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<!-- hibernate.connection.username : 连接数据库的用户名 -->
		<property name="hibernate.connection.username">root</property>
		<!-- hibernate.connection.password : 连接数据库的密码 -->	
		<property name="hibernate.connection.password">123456</property>
		<!-- hibernate.connection.url : 连接数据库的地址,路径 -->	
		<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate</property>
  1. 与本地线程绑定的配置
<property name="hibernate.current_session_context_class">thread</property>
  1. hbm2ddl.auto:是否自动生成表结构(生成表结构的策略配置)
    在这里插入图片描述

    • update值:
      • 如果数据库中没有表结构,则自动在数据库中创建一个表结构
      • 如果数据库存在表结构,并且表结构跟实体类一致,则不做修改
      • 如果数据库存在表结构,并且表结构跟实体类不一致,则会修改表结构,会保留原有列。
    • create值:
      • 无论是否存在表结构,每次启动Hibernate都会重新创新表结构(数据会丢失)
    • create-drop值:
      • 无论是否存在表结构,每次启动Hibernate都会重新创新表结构,每次Hibernate运行结束,会删除表结构
    • validate值:
      • 不会自动创建表结构,也不会自动维护表结构,Hibernate只校验表结构,如果表结构不一致,就会抛异常。
  2. 数据库方言配置
    在这里插入图片描述

    • 特定数据库有一些特定的语句,所以要识别特定的特定的数据库
    • 属性:
      • org.hibernate.dialect.MySQLDialect

实体类配置详解

  1. 实体类的编写规则:
    • 提供一个无参数 public访问控制符的构造器

    • 提供一个标识属性,映射数据表主键字段

    • 所有属性提供public访问控制符的 set get 方法(javaBean)

    • 标识属性应尽量使用基本数据类型的包装类型

      • 原因:
        • 基本数据类型和包装类型对应hibernate的映射类型相同
        • 基本类型无法表达null、数字类型的默认值为0。
        • 包装类默认值是null。当对于默认值有业务意义的时候需要使用包装类。
    • 不要用final修饰实体 (将无法生成代理对象进行优化)
      在这里插入图片描述

  2. 持久化对象的唯一标识 OID
    • Java按地址区分同一个类的不同对象.
    • 关系数据库用主键区分同一条记录
    • Hibernate使用OID来建立内存中的对象和数据库中记录的对应关系
    • 结论: 对象的OID和数据库的表的主键对应。为保证OID的唯一性,应该让Hibernate来为OID付值
  3. 区分自然主键和代理主键
    • 主键需要具备: 不为空/不能重复/不能改变
      • 自然主键: 在业务中,某个属性符合主键的三个要求.那么该属性可以作为主键列.
      • 代理主键: 在业务中,不存符合以上3个条件的属性,那么就增加一个没有意义的列.作为主键.

实体类配置文件配置

在这里插入图片描述

  1. hibernate-mapping
  2. class:配置实体与表的关系
    • name:填写实体的完整类名
    • table:与实体对应表的名称
    • dynamic-insert:动态插入 默认值是false,true=>如果字段值为null,不参与insert语句
    • dynamic-update:动态更新 默认值"false",true=> 没改动过的属性,将不会生成到update语句中
  3. id:配置实体与表中 id对应
    • name:user对象中标识主键的属性名称
    • column:主键在表中的列名
    • length:列的数据长度
    • unsaved-value(不常用):指定主键为什么值时,当做null来处理.
    • access(强烈推荐不要用):field 那么在操作属性时,会直接操作对应的字段而不是get/set方法
  4. generator:主键生成策略
    • increment :数据库自己生成主键. 先从数据库中查询最大的ID值,将ID值加1作为新的主键
    • identity:依赖于数据的主键自增功能
    • sequence:序列,依赖于数据中的序列功能(Oracle).
    • hilo(纯了解,永远用不到):Hibernate自己实现序列的算法,自己生成主键. (hilo算法 )
    • native:自动根据数据库判断,三选一. identity|sequence|hilo
    • uuid:生成32位的不重复随机字符串当做主键
    • assigned:自己指定主键值. 表的主键是自然主键时使用.
  5. property:实体中属性与表中列的对应
    • name : 实体中属性名称
    • column : 表中列的名称
    • length : 数据长度
    • precision: 小数点后的精度
    • scale: 有效位数
    • insert(一般不用): 该属性是否加入insert语句.
    • update(一般不用): 该属性是否加入update语句.
    • not-null : 指定属性的约束是否使用 非空
    • unique : 指定属性的约束是否使用 唯一
    • type: 表达该属性的类型
      • 可以用三种方式指定属性
java类型数据库类型指定Hibernate类型指定
java.lang.Stringvarcharstring

总结

主要是了解Hibernate的配置文件的详细属性了解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值