hibernate入门之环境准备,以及第一个例子。

什么是hibernate?

   Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。----来自百度百科

我的理解

   JDBC我们都知道,它可以灵活的操作数据库,完成持久层的工作。但随着使用的增多,会越发觉得不舒服或者别扭。因为java是面向对象的解释性语言,我们已经习惯了面向对象的编程,但是在操作数据库时,却要写面向关系的sql语句,而且将类中的数据存入数据库时,我们需要将变量的值一一取出,然后一一放置到数据库中,从数据库中取出值也是同理。这明显违背了面向对象的思想,按理说我们应该把数据封装成对象,然后将对象存入数据库,取出时返回的也应是对象。这就是JDBC的不足,所以hibernate应运而生。它可以代替我们完成封装对象的过程,也可以代替我们将数据库的数据以对象的方式返回给我们。而使得我们可以随心所欲的使用对象编程思维来操纵数据库。

所以,我们应该如何使用hibernate呢?

首先是资源的下载,没有它们是万万不可的(^ _^)*
1. 在hibernate官网下载hibernate文件
2. 在MySQL官网下载驱动的jar包,当然其他数据库同理。
3. JUnit官网可以根据自己需要,下载JUnit的jar包,方便我们测试。

然后是开发工具上的环境搭建,默认为Ecliplse
1. 将下载的hibernate包解压。
2. 在你的Ecliplse的java项目里,新建lib,将hibernate的lib文件里的required的jar包复制粘贴到java项目里的lib,然后再把MySQL驱动和JUnit包也拷贝到java项目里的lib里。
3. 然后build path java项目里lib里的jar包。
4. 打开hibernate文件夹,project->etc->有两个文件,分别为hibernate.cfg.xml和log4j.properties。将这两个文件拷贝到java项目里的src目录下。
5. 然后新建一个包hibernateDemo,再建一个类Student,定义三个属性id,name,age,并且生成get和set方法.
6. 打开hibernate.cfg.xml文件,将如下代码拷贝进去,这是自己的数据库相关的配置文件,具体参数可以查文档,Mysql的代码如下:

<hibernate-configuration>
    <session-factory>

        <!-- Database connection settings -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost/hibernate</property>
        <!-- 你的登录名和密码 -->
        <property name="connection.username">root</property>
        <property name="connection.password">root</property>

        <!-- JDBC connection pool (use the built-in) -->
       <property name="connection.pool_size">1</property> 

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

        <!-- Enable Hibernate's automatic session context management -->
       <property name="current_session_context_class">thread</property> 

        <!-- Disable the second-level cache  -->
        <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>

        <!-- Drop and re-create the database schema on startup -->
       <property name="hbm2ddl.auto">update</property> 

        <!-- 这个路径先别着急填 -->
        <mapping resource="hibernateDemo/Student.hbm.xml"/>

    </session-factory>

</hibernate-configuration>

7.然后在hibernateDemo包里面建立一个文件Student.hbm.xml,然后把这个文件的路径配置到刚刚的hibernate.cfg.xml里面 包名/Student.hbm.xml,如果包名含有 . 换做 /,即如果包为hibernate.test.Demo,那么配置的路径就为hibernate/test/Demo/Student.hbm.xml

<mapping resource="hibernateDemo/Student.hbm.xml"/>

8.然后就是往Student.hbm.xml里面写内容了,这里主要是类与数据库表格的映射,我们先建一个表格。打开MySql,代码如下

控制台代码

然后在Student.hbm.xml里写如下代码:

<?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="hibernateDemo">

<!-- 写你的表名 如下情况是类名与数据库的表名相同时,不要再写数据库中表的名字,不一样的话额外写下 -->
<class name="Student">
<!-- <class name="Student" table="Student">   后面的也是同理,不再解释-->

<!-- 写你的数据库表的主键名  column="id" 可以省略-->
<id name="id" column="id"></id>

<!-- 写你的其他属性名   column="name" 和column="age" 可省略 -->
<property name="name" column="name"></property>
<property name="age"  column="age"></property>

</class>
</hibernate-mapping>

以上代码主要是,说明映射关系,即你的Student类与数据库的student表格的关系,所以非常必要。

10.最后的最后建立一个StudentDemo测试类就可以了。配置完成的文件结构如下:
文件结构

经过一系列复杂的过程,我们终于可以开始编程啦(^_^

import org.hibernate.cfg.Configuration;
import org.hibernate.Session;
import org.hibernate.SessionFactory;

public class StudentTest {

    public static void main(String[] args) {
        Student s =new Student();
        s.setId(2);
        s.setName("w");
        s.setAge(23);

        Configuration cfg = new Configuration();
        SessionFactory sf=cfg.configure().buildSessionFactory();
        Session session=sf.openSession();
        session.beginTransaction();
        session.save(s);
        session.getTransaction().commit();
        session.close();
        sf.close();


    }
}

然后控制台就会输出

Hibernate: insert into Student (name, age, id) values (?, ?, ?)

这样就大功告成啦~~~~这时候查看你的数据库中的表,已经被填满信息了哦。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值