hibernate第一例
新建java项目hibernate
在hibernate项目下,新建文件夹lib,并添加jar包
旁外话:添加jar包的两种方法及区别
- 添加jar包的两种方法
- 从属性里添加jar包
- 新建文件夹,考本地jar包
- 从属性里添加jar包
- 两者区别:
- 第一种:记住添加路径,如果项目考走jar包就找不到了
- 第二种:一般使用第二种,如果项目考走jar仍然可以找的到
新建数据库hibernate
新建表user
新建domain包,封装类
User.java
package www.hbsi.com.domain;
import java.sql.Date;
public class User {
private int id;
private String name;
private Date birthday;
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;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
@Override
public String toString() {
return "User [birthday=" + birthday + ", id=" + id + ", name=" + name
+ "]";
}
}
创建配置文件
Hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- 根标签,根元素 -->
<hibernate-configuration>
<!-- session工厂 -->
<session-factory>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql:///hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<!-- 方言,连接的哪个数据库 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 执行的时候是否输出sql句 -->
<property name="show_sql">true</property>
<!-- 数据定义语言 -->
<property name="hbm2ddl.auto">update</property>
</session-factory>
</hibernate-configuration>
持久化类的映射文件
User.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="com.hbsi.domain">
<!-- 主键 -->
<class name="User" >
<id name="id">
<generator class="increment" />
</id>
<!-- 属性 -->
<property name="name" />
<property name="birthday" />
</class>
</hibernate-mapping>
让hibernate.cfg.xml知道持久化类,修改hibernate.cfg.xml
hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- 根标签,根元素 -->
<hibernate-configuration>
<!-- session工厂 -->
<session-factory>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql:///hibernate</property>
<property name="connection.username">root</property>
<property name="connection.password">123456</property>
<!-- 方言,连接的哪个数据库 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 执行的时候是否输出sql句 -->
<property name="show_sql">true</property>
<!-- 数据定义语言 -->
<property name="hbm2ddl.auto">update</property>
<!-- 加载持久化类文件 -->
<mapping resource="www/hbsi/com/domain/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
Demo1.java
package www.hbsi.com.demo;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import www.hbsi.com.domain.User;
public class Demo1 {
public static void main(String args[]){
User user = new User();
user.setName("Nacy");
user.setBirthday(new Date());
//新建一个配置对象,通过此对象加载hibernate.cfg.xml信息
Configuration cfg = new Configuration().configure();
//创建session工厂
SessionFactory sessionFactory = cfg.buildSessionFactory();
//得到session对象 相当于JDBC的Connection
Session session = sessionFactory.openSession();
//hibernate下要开启事务进行保存
session.beginTransaction();
//保存
session.save(user);
//提交事务
session.getTransaction().commit();
//关闭事务
session.close();
}
}
![](https://img-my.csdn.net/uploads/201301/03/1357178294_6034.jpg)
详解Hibernate.cfg.xml中的<property name="hbm2ddl.auto">update</property>
update作用:
- 程序代码映射关系不符合表结构,更新表结构
- 如果没有表,新建一个表
删除数据库hibernate中的user表
运行上面Demo1代码
字符串转成date类型:
create作用:
- 新建,一执行就创建,表中只能保存一条,其他记录保存不下来
create-drop作用:
- 新建,创建完之后就删除
一般都配置update
详解Hibernate.cfg.xml中的<property name="show_sql">true</property>
显不显示sql语句,如果不为true,控制台不输出sql语句
开启事务与关闭事务
![](https://img-my.csdn.net/uploads/201301/03/1357181361_5119.jpg)
![](https://img-my.csdn.net/uploads/201301/03/1357181379_7477.jpg)
回顾
- JDBC数据库连接
- JDBC的优点
- 直接底层操作,提供了很简单、便捷的访问数据库的方法,跨平台性比较强。灵活性比较强,可以写很复杂的SQL语句。
- JDBC的缺点
- 因为JAVA是面向对象的,JDBC没有做到使数据能够面向对象的编程,使程序员的思考仍停留在SQL语句上。
- 操作比较繁琐,很多代码需要重复写很多次。
- 如果遇到批量操作,频繁与数据库进行交互,容易造成效率的下降。
- JDBC的优点
引入
- 模型不匹配(阻抗不匹配)
- Java面向对象语言,对象模型,其主要概念有:继承、关联、多态等;数据库是关系模型,其主要概念有:表、主键、外键等。
- 解决办法
- 使用JDBC手工转换。
- 使用ORM(Object Relation Mapping对象关系映射)框架来解决。
- Hibernate是一个开源ORM框架。
- ORM全称Object Relation Mapping,即对象关系映射。它是一种用来完成对象模型到关系模型的映射技术。
- 就是把应用程序中的对象数据持久化到关系数据库的表的一种技术。
- 使用ORM( Object Relation Mapping )框架来解决。主流的ORM框架有JBoss公司的Hibernate、Oracle公司的TopLink、Apache组织的OJB、Sun公司的JDO。
- 简单的说:ORM能利用面向对象的思想开放基于关系型数据库的应用程序,它的主要工作是将对象数据保存到关系数据库的表中,以及将关系数据库表中数据读入到对象中。
安装配置
- 下载地址http://www.hibernate.org,使用3.3版本。
- 解压获取必需类库文件
- 将下载目录/hibernate3.jar和/lib下的hibernate运行时必须的包加入classpath中:
- 配置文件hibernate.cfg.xml和hibernate.properties,XML和properties两种,这两个文件的作用一样,提供一个即可,推荐XML格式,下载目录/etc下是示例配置文件。
- 可以在配置文件指定:
- 数据库的URL、用户名、密码、JDBC驱动类、方言等。
- 启动时Hibernate会在CLASSPATH里找这个配置文件。
- 映射文件(hbm.xml,对象模型和关系模型的映射)。在/eg目录下有完整的hibernate示例。
快速开始小例子
步骤:
- 新建java项目,并加入相应的jar包,及jdbc驱动。
- 创建持久化类
- 准备数据库表
- 创建配置文件 hibernate.cfg.xml
- 创建映射文件 xxx.hbm.xml
- 创建测试文件
- Hibernate.connection.url 表示要链接的数据库地址
- Hibernate.connection.driver_class 表示要链接的数据库的驱动类
- Hibernate.connection.username 要连接的数据库的用户名
- Hibernate.connection.password 要连接的数据库的密码
- Hibernate.dialect 表示要使用的数据库的类型
- org.hibernate.dialect.MySQL5Dialect mysql数据库
- org.hibernate.dialect.Oracle9Dialect oracle数据库
- org.hibernate.dialect.SQLServerDialect SQLServer数据库
- hibernate.hbm2ddl.auto
- validate:加载hibernate时验证创建表结构
- update:加载hibernate时自动更新数据库结构,如果表存在不用创建,如果不存在就创建。
- create:每一次加载hibernate时都创建表结构
- create-drop:加载hibernate时创建,退出时删除