Hibernate快速入门
Hibernate是一种ORM框架,全称为 Object_Relative DateBase-Mapping,在Java对象与关系数据库之间建立某种映射,以实现直接存取Java对象!
第一步 下载Hibernate
我使用的是hibernate-release-6.0.0.Alpha4.zip
压缩包解压目录介绍
第二步 导入Hibernate框架相关依赖jar包
- 先建一个项目hibernate_demo01
- 将lib下requires中所有的包导入项目(必须的jar包)
- 导入MySQL数据库的驱动jar包(这里使用的MySQL数据库)
第三步 创建数据表
create database hibernate_demo01;
use hibernate_demo01;
CREATE TABLE `user` (
`id` bigint(32)PRIMARY KEY AUTO_INCREMENT,
`name` varchar(10) NOT NULL,
`gender` enum('男','女')
)
第三步 创建实体类
- 我们在com.ll.hibernate.bean包中创建一个实体类User.java,如下:
package com.ll.hibernate.bean;
public class User {
int id;
String name;
String gender;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
}
第四步 创建映射配置文件
- 映射配置文件命名规则xx.hbm.xml
- 在com.ll.hibernate.bean中创建映射配置文件(user.hbm.xml)
- 搜索一下hibernate-release-6.0.0.Alpha4文件夹中后缀为.hbm.xml。看看它们是怎么写的。然后复制一份过来,修改成如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!-- 建立类与表的映射 -->
<class name="com.ll.hibernate.bean.User" table="user">
<!-- 建立类中的属性与表中的主键相对应 -->
<id name="id" column="id">
<!--根据底层数据库主键自动增长-->
<generator class="native" />
</id>
<!-- 建立类中的普通属性和表中的字段相对应 -->
<property name="name" column="name" />
<property name="gender" column="gender" />
</class>
</hibernate-mapping>
注意
JavaBean的主键类型只能是int类型,因为在映射关系中配置是自动增长的,String类型是不能自动增长的。
第五步 创建核心配置文件
核心配置文件hibernate.cfg.xml(它是要放在src目录下的)
- 我们可以在hibernate-release-6.0.0.Alpha4文件夹中project\etc这个目录下找到,修改后如下:
<?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>
<!-- 下面是三个必须要有的配置 -->
<!-- 配置连接MySQL数据库的基本参数 -->
<property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
<!-- 修改成自己的数据库名、登录名和密码 -->
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_demo01</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">pass</property>
<!-- 配置Hibernate的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 下面两个是可选的配置哟! -->
<!-- 打印sql语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式化sql语句 -->
<property name="hibernate.format_sql">true</property>
<!-- 告诉Hibernate的核心配置文件加载哪个映射文件 -->
<mapping resource="com/ll/hibernate/bean/user.hbm.xml"/>
</session-factory>
</hibernate-configuration>
插入数据
package com.ll.hibernate.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.ll.hibernate.bean.User;
public class Test {
public static void main(String[] args) {
// 1. 加载Hibernate的核心配置文件
Configuration configuration = new Configuration().configure();
// 如果在Hibernate的核心配置文件没有设置加载哪个映射文件,则可手动加载映射文件
// configuration.addResource("com/ll/hibernate/bean/user.hbm.xml");
// 2. 创建SessionFactory对象,类似于JDBC中的连接池
SessionFactory sessionFactory = configuration.buildSessionFactory();
// 3. 通过SessionFactory获取到Session对象,类似于JDBC中的Connection
Session session = sessionFactory.openSession();
// 4. 手动开启事务,(最好是手动开启事务)
Transaction transaction = session.beginTransaction();
// 5. 编写代码
User user = new User();
user.setName("哈哈");
user.setGender("男");
session.save(user);// 保存一个用户
// 6. 事务提交
transaction.commit();
// 7. 释放资源
session.close();
sessionFactory.close();
}
}
删除数据
User user = new User();
user.setId(1);
session.delete(user);
修改数据
User user = new User();
user.setId(1);
user.setName("嘿嘿");
session.update(user);;// 保存一个用户
//saveOrUpdate(obj)//方法中obj对象设置id时为更新,不设置id是为保存
查询数据
User user = session.get(User.class, int id);
//User user = session.load(User.class, int id); //支持懒加载