Java--Hibernate配置,基本原理,初体验

偏执的太偏执、 2023-10-05 13:03 85阅读 0赞

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行。

1、首先创建好一个数据库HibernateDB,在创建一张表product_

2、创建一个Java Project工程Hibernate,并导入所需要的包,在工程下创建一个lib文件夹,可以将包直接拖到该文件下

导包步骤: 右键project->property->java build path->libaries->add external jars

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L01pbmdnZVFpbmdjaHVu_size_16_color_FFFFFF_t_70

3、创建实体类 Product 用于映射数据库中的表product_

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L01pbmdnZVFpbmdjaHVu_size_16_color_FFFFFF_t_70 1

4、配置Product.hbm.xml

在包entity(和实体类Product一个包名下)下 新建一个配置文件Product.hbm.xml, 用于映射Product类对应数据库中的product_表

  1. <?xml version="1.0"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC
  3. "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  4. "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
  5. <hibernate-mapping package="entity">
  6. <!-- 注: 文件名 Product.hbm.xml P一定要大写,要和类保持一致 -->
  7. <!-- 表示类Product对应表product_ -->
  8. <class name="Product" table="product_">
  9. <!-- 表示属性id,映射表里的字段id -->
  10. <id name="id" column="id">
  11. <generator class="native">
  12. </generator>
  13. </id>
  14. <property name="name" />
  15. <property name="price" />
  16. </class>
  17. </hibernate-mapping>

5、配置hibernate.cfg.xml

在src目录下创建 hibernate.cfg.xml;配置访问数据库要用到的驱动,url,账号密码等等

  1. <?xml version='1.0' encoding='utf-8'?>
  2. <!DOCTYPE hibernate-configuration PUBLIC
  3. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  4. "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
  5. <hibernate-configuration>
  6. <session-factory>
  7. <!-- Database connection settings -->
  8. <property name="connection.driver_class">com.mysql.cj.jdbc.Driver</property>
  9. <property name="connection.url">jdbc:mysql://localhost:3306/HibernateDB?characterEncoding=UTF-8</property>
  10. <property name="connection.characterEncoding">utf-8</property>
  11. <property name="connection.username">root</property>
  12. <property name="connection.password">admin</property>
  13. <!-- SQL dialect -->
  14. <!-- 这表示使用MYSQL方言。 什么方言呢? 因为在代码层面,开发人员不用关心底层到底用Oracle还是Mysql,写的代码都是一样的。 可是Oracle和Mysql所用的sql语句的语法是有所区别的,那么这件事就交给Hibernate来做了。这个时候就需要告诉Hibernate底层用的是什么数据库,它才知道应该用什么样的“方言” 去对话。 -->
  15. <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
  16. <!-- 这是Hibernate事务管理方式,即每个线程一个事务 -->
  17. <property name="current_session_context_class">thread</property>
  18. <!-- 这表示是否在控制台显示执行的sql语句 -->
  19. <property name="show_sql">true</property>
  20. <!-- 这表示是否会自动更新数据库的表结构,有这句话,其实是不需要创建表的,因为Hibernate会自动去创建表结构 -->
  21. <property name="hbm2ddl.auto">update</property>
  22. <!-- 这表示Hibernate会去识别Product这个实体类 -->
  23. <mapping resource="entity/Product.hbm.xml" />
  24. </session-factory>
  25. </hibernate-configuration>

6、再创建一个测试类TestHibernate

hibernate的基本步骤是:
(1) 获取SessionFactory
(2)通过SessionFactory 获取一个Session
(3)在Session基础上开启一个事务
(4)通过调用Session的save方法把对象保存到数据库
(5)提交事务
(6)关闭Session
(7)关闭SessionFactory

  1. package hibernate;
  2. import org.hibernate.Session;
  3. import org.hibernate.SessionFactory;
  4. import org.hibernate.cfg.Configuration;
  5. import entity.Product;
  6. /* Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行
  7. * hibernate的基本步骤是:
  8. 1. 获取SessionFactory
  9. 2. 通过SessionFactory 获取一个Session
  10. 3. 在Session基础上开启一个事务
  11. 4. 通过调用Session的save方法把对象保存到数据库
  12. 5. 提交事务
  13. 6. 关闭Session
  14. 7. 关闭SessionFactory
  15. * */
  16. public class TestHibernate {
  17. public static void main(String[] args) {
  18. //1. 获取SessionFactory
  19. SessionFactory sf = new Configuration().configure().buildSessionFactory();
  20. //2. 通过SessionFactory 获取一个Session
  21. Session session = sf.openSession();
  22. //3. 在Session基础上开启一个事务
  23. session.beginTransaction();
  24. Product product = new Product();
  25. product.setName("iPhone12");
  26. product.setPrice(7000);
  27. //4. 通过调用Session的save方法把对象保存到数据库
  28. session.save(product);
  29. //5. 提交事务
  30. session.getTransaction().commit();
  31. //6. 关闭Session
  32. session.close();
  33. //7. 关闭SessionFactory
  34. sf.close();
  35. }
  36. }

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L01pbmdnZVFpbmdjaHVu_size_16_color_FFFFFF_t_70 2

这时查询一下表product_,发现已经有了该条数据

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L01pbmdnZVFpbmdjaHVu_size_16_color_FFFFFF_t_70 3

7、基本原理

应用程序通过Hibernate把 一个 Product对象插入到数据库的product_表中
hibernate.cfg.xml 配置文件提供链接数据库的基本信息
账号 密码 驱动 数据库ip 端口
Product.hbm.xml 提供对象与表的映射关系
对应哪个表? 什么属性,对应什么字段

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L01pbmdnZVFpbmdjaHVu_size_16_color_FFFFFF_t_70 4

发表评论

表情:
评论列表 (有 0 条评论,85人围观)

还没有评论,来说两句吧...

相关阅读