什么是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 (?, ?, ?)
这样就大功告成啦~~~~这时候查看你的数据库中的表,已经被填满信息了哦。