一、为什么要使用hibernate?
jdbc的优点和缺点
缺点
1、查询代码特别繁琐
2、重复性代码特别多,频繁的try,catch
3、数据的缓存
4、sql的移植性不好
优点
速度比较快
把控性比较好
ormapping框架:数据库的操作框架
优点
1、比较简单
2、数据缓存:一级缓存 二级缓存 查询缓存
3、移植性比较好
缺点
1、因为sql语句是hibernate内部生成的,所以程序员干预不了,不可控
2、如果数据库特别大,不适合用hibernate
二、*.hbm.xml(映射文件)*为持久化类名
类与表的对应关系
类上的属性的名称和表中的字段的名称对应关系
类上的属性的类型和表中的字段的类型对应关系
把一对多和多对多的关系转化成面向对象的关系
三、hibernate.cfg.xml
1、描述数据库的链接的信息
2、加载映射文件
四、sessionFactory = configuration.buildSessionFactory();
1、hibernate把数据库的链接信息、把映射文件的信息、持久化类的信息
2、sessionFactory是由单例模式产生的
3、一般情况下一个hibernate应该有一个数据库链接
4、该类本身是线程安全的
5、是一个重量级类
五、注意事项:
1、一个类是否是持久化类
1)、加载配置文件
2)、在配置文件中加载映射文件
3)、解析映射文件中class元素的name属性,找到对应的类
2、在客户端的参数的类必须是持久化类
六、对象的状态
对象的状态
临时状态
new
持久化状态
get,save,update
脱管状态
clear close evict
<set name="students" cascade="save-update">
1、在classes.hbm.xml文件,针对student进行了级联操作save-update
2、在客户端的代码中,通过班级建立班级与学生之间的关系
3、因为student是一个临时状态的对象
4、在保存班级的时候同时保存学生
inverse:
Classes.hbm.xml
<set name="students" inverse="true/false/default">
inverse
所在的映射文件classes对classes与student之间的关系是否进行维护
维护关系体现在两点:
1、在映射文件中inverse的值必须是false/default,默认值为false维护关系
2、必须在客户端代码上建立两者之间的关系
八、hibernate的组成部分
持久化类
实现对应的序列化接口
必须有默认的构造函数
持久化类的属性不能使用关键字
标示符
映射文件
类型
java类型和hibernate类型
主键的产生器
increment
说明:
1、主键的类型必须是数字
2、主键的生成是由hibernate内部完成的,程序员不需要干预
3、这种生成机制效率比较低
identity
说明:
1、新的主键的产生是由数据库完成的,并不是由hibernate或者程序员完成的
2、该表必须支持自动增长机制
3、效率比较高
assigned
说明:
1、Hibernate不负责生成主键,需要程序员自己处理主键的生成。
uuid
说明:
1、采用uuid或hilo算法生成一个主键值,这个主键值是一个不规则的长数字。这种方式生成的逐渐可以保证不重复,但是没有规律,因此不能按主键排序。
set
cascade 对象与对象之间的关系
inverse 对象与外键之间的关系
配置文件
数据库的链接信息 hibernate.cfg.xml
存放了映射文件的信息 *.hbm.xml
其他信息:hibernate内部功能的信息
<property name="show_sql">true</property>
九、hibernate的流程
Configuraction
加载了配置文件
SessionFactory
配置文件的信息、映射文件的信息、持久化类的信息
Session
1、crud的操作都是由session完成的
2、事务是由session开启的
3、两个不同的session只能用各自的事务
4、session决定了对象的状态
5、创建完一个session,相当于打开了一个数据库的链接
Transaction
1、事务默认不是自动提交的
2、必须由session开启
3、必须和当前的session绑定(两个session不可能共用一个事务)
十、hibernate的原理:
根据客户端的代码,参照映射文件,生成sql语句,利用jdbc技术进行数据库的操作
jdbc的优点和缺点
缺点
1、查询代码特别繁琐
2、重复性代码特别多,频繁的try,catch
3、数据的缓存
4、sql的移植性不好
优点
速度比较快
把控性比较好
ormapping框架:数据库的操作框架
优点
1、比较简单
2、数据缓存:一级缓存 二级缓存 查询缓存
3、移植性比较好
缺点
1、因为sql语句是hibernate内部生成的,所以程序员干预不了,不可控
2、如果数据库特别大,不适合用hibernate
二、*.hbm.xml(映射文件)*为持久化类名
类与表的对应关系
类上的属性的名称和表中的字段的名称对应关系
类上的属性的类型和表中的字段的类型对应关系
把一对多和多对多的关系转化成面向对象的关系
三、hibernate.cfg.xml
1、描述数据库的链接的信息
2、加载映射文件
四、sessionFactory = configuration.buildSessionFactory();
1、hibernate把数据库的链接信息、把映射文件的信息、持久化类的信息
2、sessionFactory是由单例模式产生的
3、一般情况下一个hibernate应该有一个数据库链接
4、该类本身是线程安全的
5、是一个重量级类
五、注意事项:
1、一个类是否是持久化类
1)、加载配置文件
2)、在配置文件中加载映射文件
3)、解析映射文件中class元素的name属性,找到对应的类
2、在客户端的参数的类必须是持久化类
六、对象的状态
对象的状态
临时状态
new
持久化状态
get,save,update
脱管状态
clear close evict
七、一对多的单项操作
如一个班级对应多个学生
<set name="students" cascade="save-update">
1、在classes.hbm.xml文件,针对student进行了级联操作save-update
2、在客户端的代码中,通过班级建立班级与学生之间的关系
3、因为student是一个临时状态的对象
4、在保存班级的时候同时保存学生
inverse:
Classes.hbm.xml
<set name="students" inverse="true/false/default">
inverse
所在的映射文件classes对classes与student之间的关系是否进行维护
维护关系体现在两点:
1、在映射文件中inverse的值必须是false/default,默认值为false维护关系
2、必须在客户端代码上建立两者之间的关系
八、hibernate的组成部分
持久化类
实现对应的序列化接口
必须有默认的构造函数
持久化类的属性不能使用关键字
标示符
映射文件
类型
java类型和hibernate类型
主键的产生器
increment
说明:
1、主键的类型必须是数字
2、主键的生成是由hibernate内部完成的,程序员不需要干预
3、这种生成机制效率比较低
identity
说明:
1、新的主键的产生是由数据库完成的,并不是由hibernate或者程序员完成的
2、该表必须支持自动增长机制
3、效率比较高
assigned
说明:
1、Hibernate不负责生成主键,需要程序员自己处理主键的生成。
uuid
说明:
1、采用uuid或hilo算法生成一个主键值,这个主键值是一个不规则的长数字。这种方式生成的逐渐可以保证不重复,但是没有规律,因此不能按主键排序。
set
cascade 对象与对象之间的关系
inverse 对象与外键之间的关系
配置文件
数据库的链接信息 hibernate.cfg.xml
存放了映射文件的信息 *.hbm.xml
其他信息:hibernate内部功能的信息
<property name="show_sql">true</property>
九、hibernate的流程
Configuraction
加载了配置文件
SessionFactory
配置文件的信息、映射文件的信息、持久化类的信息
Session
1、crud的操作都是由session完成的
2、事务是由session开启的
3、两个不同的session只能用各自的事务
4、session决定了对象的状态
5、创建完一个session,相当于打开了一个数据库的链接
Transaction
1、事务默认不是自动提交的
2、必须由session开启
3、必须和当前的session绑定(两个session不可能共用一个事务)
十、hibernate的原理:
根据客户端的代码,参照映射文件,生成sql语句,利用jdbc技术进行数据库的操作