一、简介

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语句对数据库执行操作!

  

    

1.一起来学hibernate之hibernate简介的更多相关文章

  1. Hibernate(一)__简介

    一. hibernate是什么 (一)hibernate 是一个orm框架,orm (object relation mapping) 对象关系映射框架 o object -> 业务层(只对对象 ...

  2. 【hibernate】hibernate和mybatis的比较

    理解和学习,使自己在做项目中更加得心应手. 第一方面:开发速度的对比就开发速度而言,Hibernate的真正掌握要比Mybatis来得难些.Mybatis框架相对简单很容易上手,但也相对简陋些.个人觉 ...

  3. Hibernate→ 《Hibernate程序开发》教材大纲

    Hibernate ORM 概览 Hibernate 简介 Hibernate 架构 Hibernate 环境 Hibernate 配置 Hibernate 会话 Hibernate 持久化类 Hib ...

  4. 问题Initial SessionFactory creation failed.org.hibernate.HibernateException: /hibernate.cfg.xml not found解决方法

    问题Initial SessionFactory creation failed.org.hibernate.HibernateException: /hibernate.cfg.xml not fo ...

  5. org.hibernate.HibernateException: /hibernate.cfg.xml not found等三个问题

    初次配置hibernate在myeclipse上: 出现三个问题,怎么都不好使,比对代码,没有问题,查看路径还是没有问题: 1.org.hibernate.HibernateException: /h ...

  6. Hibernate之Hibernate环境搭建

    Hibernate之Hibernate环境搭建 一.Hibernate环境搭建的步骤 1.添加Hibernate && SQLServer 的Jar antlr-2.7.7.jar d ...

  7. 【hibernate】Hibernate中save, saveOrUpdate, persist, merge, update 区别

    Hibernate Save hibernate save()方法能够保存实体到数据库,正如方法名称save这个单词所表明的意思.我们能够在事务之外调用这个方法,这也是我不喜欢使用这个方法保存数据的原 ...

  8. 【Hibernate】Hibernate的多表查询

    在<[Hibernate]Hibernate的聚类查询.分组查询.排序与时间之差>(点击打开链接)一文中已经讲述过怎样利用HQL语句代替SQL语句.进行聚类查询.分组查询.排序与时间之差的 ...

  9. Structs hibernate spring=ssh简介

    Structs  hibernate  spring Struts Struts是一个基于Sun J2EE平台的MVC框架,主要是采用Servlet和JSP技术来实现的. Struts框架可分为以下四 ...

随机推荐

  1. lua 和 c

    lua程序其实本身并不能执行,它必须依靠c语言编写的解释器来解释执行,或者说解释器为lua脚本的执行,提供了一个运行环境(lua_state),其中包括函数堆栈,内存分配和回收等机制. 理论上,lua ...

  2. 获取body标签元素方法

    方法一 doucumnet.body 方法二 document.getElementsByTagName("body")[0]

  3. linux shell学习笔记

    一  变量 声明变量: my_var='ddd'使用变量: ${my_var}设置为只读变量: readonly my_var删除变量: unset my_var 注意只读变量不能被删除 变量类型:( ...

  4. 【转载】C++ function、bind和lambda表达式

    本篇随笔为转载,原贴地址:C++ function.bind和lambda表达式. 本文是C++0x系列的第四篇,主要是内容是C++0x中新增的lambda表达式, function对象和bind机制 ...

  5. information_schema系列三(文件,变量)

    这个系列的文章主要是为了能够让自己了解MySQL5.7的一些系统表,统一做一下备注和使用,也希望分享出来让大家能够有一点点的受益. 1:FILES 这张表提供了有关在MySQL的表空间中的数据存储的文 ...

  6. SQL常用代码收集

    1.存储过程中,使用in查询时的参数处理方式 使用情形描述:传入存储过程的参数为一个字符串@IDs,以固定分隔符连接 新建字符串分割函数,然后将分割结果传入存储过程: CREATE FUNCTION ...

  7. cs0006 未能找到元数据文件 C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files

    翻阅了一些资料后发现是需要重新注册IIS服务扩展,在“开始”-“运行”里输入如入命令,回车,搞定 C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727\aspne ...

  8. collectionView使用细节

    1.//创建组头组尾一个方法 - (UICollectionReusableView *)stCollectionView:(UICollectionView *)collectionView vie ...

  9. poj 2239 Selecting Courses (二分匹配)

    Selecting Courses Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8316   Accepted: 3687 ...

  10. HTML小知识---Label

    今天知道了一个html小知识: <input type="checkbox" id="chkVersion" />                 ...