Hibernate入门简介

Posted smellpawn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate入门简介相关的知识,希望对你有一定的参考价值。

什么是Hibernate框架?

Hibernate是一种ORM框架,全称为 Object_Relative DateBase-Mapping,在Java对象与关系数据库之间建立某种映射,以实现直接存取Java对象

为什么要使用Hibernate?

 既然Hibernate是关于Java对象和关系数据库之间的联系的话,也就是我们MVC中的数据持久层->在编写程序中的DAO层...

首先,我们来回顾一下我们在DAO层写程序的历程吧:

  1. 在DAO层操作XML,将数据封装到XML文件上,读写XML文件数据实现CRUD
  2. 在DAO层使用原生JDBC连接数据库,实现CRUD
  3. 嫌弃JDBC的Connection\\Statement\\ResultSet等对象太繁琐,使用对原生JDBC的封装组件-->DbUtils组件

我们来看看使用DbUtils之后,程序的代码是怎么样的:

public class CategoryDAOImpl implements zhongfucheng.dao.CategoryDao {

    @Override
    public void addCategory(Category category) {

        QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource());

        String sql = "INSERT INTO category (id, name, description) VALUES(?,?,?)";
        try {
            queryRunner.update(sql, new Object[]{category.getId(), category.getName(), category.getDescription()});

        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }

    @Override
    public Category findCategory(String id) {
        QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource());
        String sql = "SELECT * FROM category WHERE id=?";

        try {
            Category category = (Category) queryRunner.query(sql, id, new BeanHandler(Category.class));

            return category;

        } catch (SQLException e) {
            throw new RuntimeException(e);
        }

    }

    @Override
    public List<Category> getAllCategory() {
        QueryRunner queryRunner = new QueryRunner(Utils2DB.getDataSource());
        String sql = "SELECT * FROM category";

        try {
            List<Category> categories = (List<Category>) queryRunner.query(sql, new BeanListHandler(Category.class));

            return categories;
        } catch (SQLException e) {
            throw  new RuntimeException(e);
        }

    }
}

其实使用DbUtils时,DAO层中的代码编写是很有规律的。

  • 当插入数据的时候,就将JavaBean对象拆分,拼装成SQL语句
  • 当查询数据的时候,用SQL把数据库表中的列组合,拼装成JavaBean对象

也就是说:javaBean对象和数据表中的列存在映射关系!如果程序能够自动生成SQL语句就好了....那么Hibernate就实现了这个功能!

简单来说:我们使用Hibernate框架就不用我们写很多繁琐的SQL语句,从而简化我们的开发!

ORM概述

在介绍Hibernate的时候,说了Hibernate是一种ORM的框架。那什么是ORM呢?ORM是一种思想

  • O代表的是Objcet
  • R代表的是Relative
  • M代表的是Mapping

ORM->对象关系映射....ORM关注是对象与数据库中的列的关系

技术图片

Hibernate快速入门

学习一个框架无非就是三个步骤:

  • 引入jar开发包
  • 配置相关的XML文件
  • 熟悉API

引入相关jar包

我们使用的是Hibernate3.6的版本

hibernate3.jar核心 + required 必须引入的(6个) + jpa 目录 + 数据库驱动包

技术图片

编写对象和对象映射

编写一个User对象->User.java

1 public class User {
2     
3     private int id;
4     private String username;
5     private String password;
6     private String cellphone;
7 
8     //各种的setter和getter就不一一展示了
9 }

再写一个数据库表,属性和User的属性一致。

编写对象映射->User.hbm.xml。一般它和JavaBean对象放在同一目录下

如果不知道该XML是怎么写的,可以搜索一下Hibernate文件夹中后缀为.hbm.xml。看看它们是怎么写的。再依葫芦画瓢

 1 <!--在domain包下-->
 2 <hibernate-mapping package="qinkang.domain">
 3 
 4     <!--类名为User,表名也为User-->
 5     <class name="User"  table="user">
 6 
 7         <!--主键映射,属性名为id,列名也为id-->
 8         <id name="id" column="id">
 9             <!--根据底层数据库主键自动增长-->
10             <generator class="native"/>
11 
12         </id>
13         
14         <!--非主键映射,属性和列名一一对应-->
15         <property name="username" column="username"/>
16         <property name="cellphone" column="cellphone"/>
17         <property name="password" column="password"/>
18     </class>
19 </hibernate-mapping>

主配置文件

hibernate.cfg.xml

如果使用Intellij Idea生成的Hibernate可以指定生成出主配置文件hibernate.cfg.xml,它是要放在src目录下的

如果不是自动生成的,我们可以在Hibernate的hibernate-distribution-3.6.0.Final\\project\\etc这个目录下可以找到。在依葫芦画瓢

 1 <hibernate-configuration>
 2     <!-- 通常,一个session-factory节点代表一个数据库 -->
 3     <session-factory>
 4 
 5         <!-- 1. 数据库连接配置 -->
 6         <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
 7         <property name="hibernate.connection.url">jdbc:mysql:///qinkang</property>
 8         <property name="hibernate.connection.username">root</property>
 9         <property name="hibernate.connection.password">root</property>
10         <!--
11             数据库方法配置, hibernate在运行的时候,会根据不同的方言生成符合当前数据库语法的sql
12          -->
13         <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
14 
15 
16         <!-- 2. 其他相关配置 -->
17         <!-- 2.1 显示hibernate在运行时候执行的sql语句 -->
18         <property name="hibernate.show_sql">true</property>
19         <!-- 2.2 格式化sql -->
20         <property name="hibernate.format_sql">true</property>
21         <!-- 2.3 自动建表  -->
22         <property name="hibernate.hbm2ddl.auto">create</property>
23 
24         <!--3. 加载所有映射-->
25         <mapping resource="qinkang/domain/User.hbm.xml"/>
26 
27     </session-factory>
28 </hibernate-configuration>

测试

 1 package qinkang.domain;
 2 
 3 import org.hibernate.SessionFactory;
 4 import org.hibernate.Transaction;
 5 import org.hibernate.cfg.Configuration;
 6 import org.hibernate.classic.Session;
 7 
 8 /**
 9  * Created by ozc on 2017/5/6.
10  */
11 public class App {
12     public static void main(String[] args) {
13 
14         //创建对象
15         User user = new User();
16         user.setPassword("123");
17         user.setCellphone("122222");
18         user.setUsername("nihao");
19 
20         //获取加载配置管理类
21         Configuration configuration = new Configuration();
22 
23         //不给参数就默认加载hibernate.cfg.xml文件,
24         configuration.configure();
25 
26         //创建Session工厂对象
27         SessionFactory factory = configuration.buildSessionFactory();
28 
29         //得到Session对象
30         Session session = factory.openSession();
31 
32         //使用Hibernate操作数据库,都要开启事务,得到事务对象
33         Transaction transaction = session.getTransaction();
34 
35         //开启事务
36         transaction.begin();
37 
38         //把对象添加到数据库中
39         session.save(user);
40 
41         //提交事务
42         transaction.commit();
43 
44         //关闭Session
45         session.close();
46     }
47 }

技术图片

hibernate流程

 

技术图片

 

以上是关于Hibernate入门简介的主要内容,如果未能解决你的问题,请参考以下文章

Hibernate入门简介----张冬

Hibernate入门简介

Hibernate入门----配置文件

Hibernate的入门Curd用法

Hibernate框架入门

JAVA入门[20]-Hibernate简单示例