什么是Hibernate?
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的JaveEE架构中取代CMP,完成数据持久化的重任。
Hibernate的特点:
1,将对数据库的操作转换为对Java对象的操作,从而简化开发。通过修改一个“持久化”对象的属性从而修改数据库表中对应的记录数据。,
2,提供线程和进程两个级别的缓存提升应用程序性能。
3,有丰富的映射方式将Java对象之间的关系转换为数据库表之间的关系。,
4,屏蔽不同数据库实现之间的差异。在Hibernate中只需要通过“方言”的形式指定当前使用的数据库,就可以根据底层数据库的实际情况生成适合的SQL语句。
5,非侵入式:Hibernate不要求持久化类实现任何接口或继承任何类,POJO即可。
核心API:
Hibernate的API一共有6个,分别为:Session、SessionFactory、Transaction、Query、Criteria和Configuration。通过这些接口,可以对持久化对象进行存取、事务控制。
Session
Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句)。但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。
SessionFactory
SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。
Transaction
Transaction 接口是一个可选的API,可以选择不使用这个接口,取而代之的是Hibernate 的设计者自己写的底层事务处理代码。 Transaction 接口是对实际事务实现的一个抽象,这些实现包括JDBC的事务、JTA 中的UserTransaction、甚至可以是CORBA 事务。之所以这样设计是能让开发者能够使用一个统一事务的操作界面,使得自己的项目可以在不同的环境和容器之间方便地移植。
Query
Query接口让你方便地对数据库及持久对象进行查询,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作。
Criteria
Criteria接口与Query接口非常类似,允许创建并执行面向对象的标准化查询。值得注意的是Criteria接口也是轻量级的,它不能在Session之外使用。
Configuration
Configuration 类的作用是对Hibernate 进行配置,以及对它进行启动。在Hibernate 的启动过程中,Configuration 类的实例首先定位映射文档的位置,读取这些配置,然后创建一个SessionFactory对象。虽然Configuration 类在整个Hibernate 项目中只扮演着一个很小的角色,但它是启动hibernate 时所遇到的第一个对象。
Hibernate入门
搭建hibernate环境
第一步,首先在pom.xml中引入依赖:
<dependencies>
<!-- hibernate的依赖 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>5.2.10.Final</version>
</dependency>
<!-- mysql的依赖 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
</dependencies>
第二步,创建实体类:
public class User implements Serializable {
private static final long serialVersionUID = 5141627435842343658L;
private int uid;
private String username;
private String password;
private String address;
public int getUid() {
return uid;
}
public void setUid(int uid) {
this.uid = uid;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
第三步,配置实体类和数据库表:
注意:
使用hibernate时候,不需要自己手动创建表,hibernate会帮我们把表创建,只需要使用配置文件实现映射关系即可
(1)创建xml格式的配置文件
-
映射配置文件名称和位置没有固定要求
-
建议:实体类名称.hbm.xml
(2)配置是xml格式,在配置文件中要引入xml约束
拉到最下边找到:hibernate-mapping-3.0.dtd 文件:
复制dtd约束:
完整的实体类和数据库表映射xml文件:
下边是代码:<hibernate-mapping> <class name="hibernate.entity.User" table="t_user"> <id name="uid" column="uid" > <generator class="native"></generator> </id> <property name="username" column="username" /> <property name="password" column="password" /> <property name="address" column="address" /> </class> </hibernate-mapping>
第四步,创建hibernate的核心配置文件:
(1)核心配置文件格式xml,但是核心配置文件名称和位置固定的、
- 名称:必须hibernate.cfg.xml
(2)引入dtd约束:
和上边一样,不同的是这次的dtd文件名是:hibernate-configuration-3.0.dtd**
复制dtd约束:
(3)hibernate操作过程中,只会加载核心配置文件,其他配置文件不会加载:
第一部分:配置数据库信息必须的:
第二部分:配置hibernate信息,这一步可选可不选:
第三部分:把映射文件放到核心配置文件中:
完整代码:
<!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.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<!-- 第二步:配置hibernate信息 -->
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<property name="hbm2ddl.auto">update</property>
<!-- 数据库方言配置 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 第三步:引入映射文件 填写src之后的路径 -->
<mapping resource="User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
第四部分,实现添加数据库表和表数据操作:
(1)创建sessionFactory过程中,这个过程特别消耗资源
- 在hibernate操作中,建议一个项目一般创建一个sessionFactory对象
具体实现:
-
写工具类,写静态代码块实现
-
静态代码块在类加载时候执行,执行一次
(2)实现代码:
最后查询数据库查看结果:
注意:
hibernate.cfg.xml配置了下面语句后:
<property name="hibernate.hbm2ddl.auto">update</property>
会通过hbm生成一个sql语句来创建表,
如果配置了下面的语句:
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
而且你使用的mysql是5.x,那么会报错: type=MyISAM
解决方法是:
配置改成:
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
就可以完美运行了~