Hibernate学习总结(1)——快速上手hibernate操作数据库

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语句


则说明测试成功了,再看看数据库的变化


不仅在数据库中创建了表,还创建了我们的测试数据。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值