Hibernate学习总结(1)——快速上手hibernate操作数据库
程序员文章站
2024-03-23 12:58:34
...
Hibernate是一个 Java 领域的持久化的,ORM框架。
常见的ORM框架有Hibernate、MyBatis等。
首先了解一下什么是ORM
ORM英文全称为Object Relational Mapping,即对象关系映射。
ORM的思想便是将关系数据库中表中的记录映射成为对象,以对象的形式展现,程序员可以把对数据库的操作转化为对对象的操作。即我们在数据库中的一条信息,会存在一个类,类中的属性,与数据库中信息的每个字段相对应。
ORM 采用元数据来描述对象-关系映射细节,元数据通常采用XML格式,并且存放在专门的对象-关系映射文件中.
这里借鉴一下他人的一个关于ORM和XML文件的逻辑图。
Hibernate的开发步骤:
0.首先是导入jar包
1.创建持久化类
•需要提供一个无参的构造器:使Hibernate可以使用Constructor.newInstance()来实例化持久化类
•提供一个标识属性(identifier property): 通常映射为数据库表的主键字段.(通常为id属性)如果没有该属性,一些功能将不起作用,如:Session.saveOrUpdate()
•为类的持久化类字段声明访问方法(get/set):Hibernate对JavaBeans风格的属性实行持久化。
•使用非 final类: 在运行时生成代理是Hibernate的一个重要的功能.如果持久化类没有实现任何接口,Hibnernate使用CGLIB生成代理.如果使用的是final类,则无法生成CGLIB代理.
•重写 eqauls和hashCode方法:如果需要把持久化类的实例放到Set中(当需要进行关联映射时),则应该重写这两个方法
一个简单的User类:
package com.hibernate.entity;
public class User {
private int uid;
private String username;
private String password;
private String address;
public int getUid() {
return uid;
}
public String getUsername() {
return username;
}
public String getPassword() {
return password;
}
public String getAddress() {
return address;
}
public void setUid(int uid) {
this.uid = uid;
}
public void setUsername(String username) {
this.username = username;
}
public void setPassword(String password) {
this.password = password;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return "User [uid=" + uid + ", username=" + username + ", password=" + password + ", address=" + address + "]";
}
}
2.创建对象关系映射文件
•Hibernate 采用 XML格式的文件来指定对象和关系数据之间的映射.
在运行时Hibernate将根据这个映射文件来生成各种SQL语句
•映射文件的扩展名为 .hbm.xml(如:User.hbm.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>
<!-- 1.配置数据库信息 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/javadatabase</property>
<property name="connection.username">root</property>
<property name="connection.password">zrx13699496795</property>
<!-- 2.配置hibernate信息(可选) -->
<!-- 输出底层sql语句 -->
<property name="show_sql">true</property>
<!-- 输出底层sql语句格式 -->
<property name="format_sql">true</property>
<!-- hibernate帮创建表,需要配置之后
update:如果已经表存在,则更新,不存在,则创建
-->
<property name="hbm2ddl.auto">update</property>
<!-- 配置数据库方言
在MySQL里面实现分页关键字limit,只能使用MySQL里
在oracle数据库,实现发页用rownum
让hibernate框架识别不同数据库的自己特有的语句
-->
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<!-- 3.把映射文件放到核心配置文件中 -->
<mapping resource="User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
3.创建核心配置文件
位置:必须在src下
名称:必须为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>
<!-- 1.配置数据库信息 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/javadatabase</property>
<property name="connection.username">root</property>
<property name="connection.password">******</property><!--使用你自己对应数据库的密码-->
<!-- 2.配置hibernate信息(可选) -->
<!-- 输出底层sql语句 -->
<property name="show_sql">true</property>
<!-- 输出底层sql语句格式 -->
<property name="format_sql">true</property>
<!-- hibernate帮创建表,需要配置之后
update:如果已经表存在,则更新,不存在,则创建
-->
<property name="hbm2ddl.auto">update</property>
<!-- 配置数据库方言
在MySQL里面实现分页关键字limit,只能使用MySQL里
在oracle数据库,实现发页用rownum
让hibernate框架识别不同数据库的自己特有的语句
-->
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<!-- 3.把映射文件放到核心配置文件中 -->
<mapping resource="User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
4.数据库操作代码
@Test
public void addTest(){
//1.加载hibernate核心配置文件
//在src下找到hibernate.cfg.xml文件
Configuration cfg = new Configuration().configure();
//2.创建SessionFactory对象
//读取hibernate核心配置文件内容,创建SessionFactory
//根据映射关系,在配置数据库里把表创建
SessionFactory sessionFactory = cfg.buildSessionFactory();
//3.使用SessionFactory创建session对象
//类似于连接
Session session = sessionFactory.openSession();
//4.开启事务
Transaction tx = session.beginTransaction();
//5.具体逻辑crud操作
User user = new User();
user.setUsername("张三");
user.setPassword("123456");
user.setAddress("山东");
//调用session的方法实现添加
session.save(user);
//6.提交事务
tx.commit();
//7.关闭资源
session.close();
sessionFactory.close();
}
执行代码后会在控制台中看到相应的日志等信息的输出,还会看到一个sql语句
则说明测试成功了,再看看数据库的变化
不仅在数据库中创建了表,还创建了我们的测试数据。
上一篇: AQS 简单介绍
下一篇: Python的一道面试题