1.一起来学hibernate之hibernate简介

时间:2021-09-19 21:43:38

一、简介

Hibernate,是一个开源的ORM框架。所谓的ORM,即object relative mapping,就是对象关系映射。

那什么是对象关系映射?

  对象,即java类,又称为实体类,对象一般用来存放数据;

  关系:即关系型数据库,例如mySQL、oracle、DB2等等都是关系型数据库;

  映射:个人理解为对象和数据库的表一一对应的桥梁,即实体对应数据库表,属性对应表中列。

那为什么需要hibernate?

  hibernate提供一套api供开发者调用,通过api,可以简化对数据库的操作,可以让开发者不需要写太多的sql语句就能完成对数据库的操作,例如save(entity),那么hibernate会自动生成一条insert into 语句,然后将entity内的数据插入到数据库中;

  hibernate提供不同的方言,不同的方言支持不同的关系型数据库,由于不同的数据库使用起来或多或少都有些不同,如果切换数据库那么很多sql语句必须修改,所以使用hibernate无需修改sql代码,hibernate自身会通过方言生成合适的sql语句,这样就可以达到随心所欲切换数据库;

  当然,hibernate还有很多优点,当然这里仅仅罗列比较出色的优点。

学习hibernate,需要学习什么?

  除了hibernate提供给开发者的api,还需要学习如何配置!

  为什么要配置?

    假如需要将一个实体内的数据插入到数据库表中,数据库如何知道数据是插入哪张表,如何知道插入哪一列?所以配置是为了将实体对应到数据库中指定的表,将实体内属性对应到表中的列。

二、实践(一个小案例)

需求:将实体User内数据存入数据库sys_user表中

环境:

  1.添加jar包

hibernate3.jar
antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
javassist-3.12.0.GA.jar
jta-1.1.jar
slf4j-api-1.6.1.jar
hibernate-jpa-2.0-api-1.0.0.Final.jarmysql-connector-java-5.1.5-bin.jar

  2.使用eclipse创建project工程---hibernate

  3.在classpath 创建一个lib文件夹,添加以上jar包,并将jar包add buildpath

  4.创建实体类User

public class User {

    private int id;
    private String name;

    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;
    }

    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + "]";
    }

}

  5.在创建sys_user表

create table sys_user(
    id  int  primary key not null  auto_increment,
    name  )
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

  6.涉及到数据库操作,自然要连接数据库,在classpath下创建hibernate.cfg.xml文件,配置如下:

<!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 name="foo">
        <!-- 配置数据库信息 -->
        <!-- 配置数据库方言 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <!-- 配置数据库url -->
        <property name="connection.url">jdbc:mysql:///hibernate</property>
        <!-- 配置数据库驱动(mysql) -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!-- 配置数据库用户名 -->
        <property name="connection.username">root</property>
        <!-- 配置数据库密码 -->
        <property name="hibernate.connection.password">1208</property>

        <!-- 是否显示sql -->
        <property name="hibernate.show_sql">true</property>

        <!-- 导入映射文件 该文件就是实体与数据库表之间的对应关系-->
        <mapping resource="com/hibernate/User.hbm.xml"/>
    </session-factory>
</hibernate-configuration>

  7.创建User.hbm.xml映射文件,配置User和sys_user之间的对应关系

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 实体类包路径 -->
<hibernate-mapping package="com.hibernate">
    <!-- 实体的名称、对应表名 -->
    <class name="User" table="sys_user">
        <!-- 主键id、主键id类型、在表中的列名 -->
        <id name="id" type="int" column="id">
            <!-- 自动增长 -->
            <generator class="native"/>
        </id>
        <!-- 实体属性名、实体属性类型、在表中的列名 -->
        <property name="name" type="string" column="name" length="20"/>
    </class>
</hibernate-mapping>

  8.测试程序

public class TestHibernate {

    private static SessionFactory sessionFactory;

    static {
        Configuration cfg = new Configuration(); //用来维护配置文件的类
        cfg.configure("hibernate.cfg.xml"); // 读取指定的主配置文件
        sessionFactory = cfg.buildSessionFactory(); //根据配置文件生成Session工厂
    }

    public static void main(String[] args) {
        User u = new User();
        u.setName("save");

        Session session = sessionFactory.openSession(); //打开一个新的Session
        Transaction tx = session.beginTransaction(); //开始事务,执行操作失败后进行数据回滚
        session.save(u);//保存
        tx.commit(); //提交事务
        session.close(); //关闭Session,释放资源
    }
}

运行结果:

  控制台打印:Hibernate: insert into sys_user (name) values (?)

运行成功!

总结:

  调用save方法,传入实体,hibernate根据配置文件一一对应实体和数据表并生成sql语句对数据库执行操作!