1.) 用途: 直接处理javabean,不再去写sql语句
2.) 能在javabean的层次上实现一对多或是多对多的关系
2. 为什么要用hibernate
1) hibernate对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码
2) hibernate是一个轻量级框架,关系映射很灵活,支持很多种关系型数据库,从一对一到多对多的各种复杂关系 (轻量级意思是没有全部封装)
3) Hibernate是对JDBC进行封装,所以在大型项目中效率比较低,速度比较慢,大型项目还是采用JDBC进行开发中小型项目还是采用hibernate开发
3. 建立与数据库的连接方式
1.) 使用hibernate.properties
## MySQL
hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.connection.driver_class=com.mysql.jdbc.Driver
hibernate.connection.url=jdbc:mysql:///day01?useUincode&characterEncoding=UTF-8
hibernate.connection.username=root
hibernate.connection.password=root
hibernate.connection.pool_size=1
#是否格式化sql
hibernate.format_sql=true
hibernate.show_sql=true
##每次执行的批处理语句是多少
hibernate.default_batch_fetch_size=8
##设置事务的隔离级别 1, 2, 4,8默认就是4
hibernate.connection.isolation=4
2.) 使用hibernate.cfg.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
<!-- 配置数据库的方言,让hibernate知道连接的是那个数据库 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 显示hibernate生成的sql语句 -->
<property name="hibernate.show_sql">true</property>
<!--
配置数据库的隔离级别,数据库中的四种隔离级别,分别对应的值
1: Read uncommitted isolation
2: Read committed isolation
4: Repeatable read isolation
8: Serializable isolation
-->
<property name="hibernate.connection.isolation">2</property>
<mapping resource=”cn/itcast/primer/Customer.hbm.xml”></mapping>
</session-factory>
</hibernate-configuration>
4. Hibernate是如何来操作数据库中表的?
(1). hibernate必须要将表结构抽象成一个javaBean.
(2). 用一个JavaBean和一个XML文件来完成从JavaBean到数据库的映射。
(3). 通过Session(connectoin)类,它的save(JavaBean)即可以直接保存数据。
(4). 之前的Connection默认是自动提交事务的,但Session对Connection进行了封装,不是自动提交事务的。
所以必须要手工开启和提交事务(可以不手动开始,默认会开启)
(5). hibernate是如何实现写入到表中的呢?有没有执行sql?
- insert.如何才可以看到insert语句。通过配置,可以让hiberante告诉我们,hiberneta是如何执行的sql语句。