介绍
回顾下之前的开发,了解需求之后,根据界面模型建立数据库,再根据数据库建立实体模型,如果数据库更改,实体模型也跟着改,也就是说实体或者说对象是依赖数据库的。这就使得我们进行面对对象开发有了一定的阻碍。
ORM,Object Relational Mapping,对象关系映射。是由对象到关系数据的映射,解决了这个问题——面向对象与关系数据库的不匹配的现象。
Hibernate就是开源的非常优秀的ORM框架。它在这两种不同的模型之间建立关联,给我们提供了利用面向对象的思想来操作关系型数据的接口。
第一个hibernate项目
1、创建java项目
2、创建UserLibrary,加入依赖包
*HIBERNATE_HOME/lib/*.jar
*HIBERNATE_HOME/hibernate3.jar
*加入数据库驱动(mysql驱动)
3、提供hibernate.cfg.xml文件,完成基本的配置
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/hibernateFirst
root
root
org.hibernate.dialect.HSQLDialect
true
true
4、建立实体类User.java
public class User {
private String id;
private String name;
private String password;
private Date createTime;
private Date expireTime;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public Date getCreateTime() {
return createTime;
}
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
public Date getExpireTime() {
return expireTime;
}
public void setExpireTime(Date expireTime) {
this.expireTime = expireTime;
}
}
5、提供User.hbm.xml文件,完成实体类的映射
6、将User.hbm.xml文件加入到hibernate.cfg.xml文件中
7、编写工具类ExoprtDB.java,将hbm生成ddl,也就是hbm2ddl,用来创建表
/**
* 将hbm生成ddl
* @author Administrator
*
*/
public class ExportDB {
public static void main(String[] args) {
//默认读取hibernate.cfg.xml文件
Configuration cfg = new Configuration().configure();
SchemaExport export = new SchemaExport(cfg);
export.create(true, true);
}
}
最好加入如下配置项,方便观察hibernatesql的生成:
true
true
最好加入log4j配置文件,将该配置文件拷贝到src下,跟踪执行信息,便于程序的调试,而且可以选择性的显示
小结
hibernate使得我们可以面向对象编程,一直在跟对象打交道,是因为hibernate制定了一套由实体到数据库表的映射机制,根据实体信息执行相应的sql语句,从而省去了建立数据库表的过程,建表如此,对表的增删改查也是如此,hibernate都为我们封装好了,封装的就是我们常用的jdbc操作,随着这些jdbc操作没什么,但难能可贵的是能够从中发现大量重复代码并抽象出这个框架,更值得学习的是这个框架考虑的方方面面。
作者:tcl_6666 发表于2013-6-20 17:23:38 原文链接
阅读:60 评论:0 查看评论