Hibernate是轻量级Java EE应用的持久层解决方案,Hibernate实现Java类到数据库表的映射(包括Java 数据类型到SQL数据类型的映射),
还提供数据查询和获取数据的方法,可以大幅度的缩短使用JDBC处理数据持久化的时间。
Hibernate对JDBC 进行轻量级封装
ORM (Object/Relationship Mapping ) :对象/关系映射
它的作用是在关系型数据库和业务实体对象之间作一个映射。
ORM方法论应当基于三个核心原则:
简单:以最基本的形式建模数据。
传达性:数据库结构被任何人都能理解的语言文档化。
精确性:基于数据模型创建正确标准化了的结构。
为什么要用ORM?
写SQL语句不好吗?
1.不同的数据库使用的SQL语法不同。比如:PL/SQL 与 T/SQL
2.同样的功能在不同的数据库中有不同的实现方式
3.程序过分依赖SQL对程序的移植及扩展,维护等带来很大的麻烦。
hibernate 完成一般步骤
1. 创建hibernate的配置文件 hibernate-cfg.xml
hibernate.show_sql 是否输出到控制台
hibernate.format_sql 是否对输出控制台的SQL语句进行打印
hbm2ddl.auto 可以帮助java代码生成数据库脚本
2. 创建持久化类
3. 创建对象-关系映射文件
4. 通过Hibernate API 编写访问数据库的代码
hibernate 的执行流程
1. 创建configuration对像 (hibernate-cfg.xml)
2. 生成SessionFactory (加载映射关系 user.hbrn.xml)
3. 创建Session对象 (相当于JDBC的connection)
4. 执行各种数据库操作
Session可以理解为操作数据库的对象
Session与Connection 是多对一的关系 一个Session有一个对应的connection
一个Connection 可以支持多个Session
把对象保存在关系数据库中需要调用session的各种方法 如:save()/update()/delete()
createQuery()等
如何获取session对象
1)openSession
2)getCurrentSession
二者的区别:
1.getCurrentSession在事务提交或者回滚之后会自动关闭,而openSession需要手动关闭
如果使用openSession 而没有手动关闭,多次之后会导致连接池溢出。
2.openSession每次创建新的Session对象,getCurrentSession使用现有的Session对象
transaction 介绍
hibernate对数据的操作都是封装在事务当中,并且默认是非自动提交的方式。所以用session保存对象时
如果不开启事务,并且手工提交事务,对象并不会真正保存在数据库中
JDBC是自动提交事务
单一主键
<generator class="assigned" /> ---主键生成策略
assigned--- 由java应用程序负责生成(手动赋值)
native 由底层数据库自动生成表示符,如果是mysql就是increment,如果是Oracle就是sequence,等等