您的位置:首页 > 其它

Hibernate初认识以及HelloWorld

2015-07-16 20:04 411 查看
一、Hibernate初认识

1、 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。

2、对于对象持久化的理解:

a.狭义的理解,“持久化”仅仅指把对象永久保存到数据库中

b.广义的理解,“持久化”包括和数据库相关的各种操作:
–保存:把对象永久保存到数据库中。

–更新:更新数据库中对象(记录)的状态。

–删除:从数据库中删除一个对象。

–查询:根据特定的查询条件,把符合查询条件的一个或多个对象从数据库加载到内存中。




–加载:根据特定的OID,把一个对象从数据库加载到内存中。





3、 ORM(Object/Relation Mapping)对象/关系映




–ORM 主要解决对象-关系的映射



面向对象 面向关系
对象表的行(记录)
属性表的列(z字段)
–ORM的思想:将关系数据库中表中的记录映射成为对象,以对象的形式展现,把对数据库的操作转化为对对象的操作。


–ORM 采用元数据来描述对象-关系映射细节,元数据通常采用XML格式,并且存放在专门的对象-关系映射文件中.





二、Hibernate初使用之HelloWrld

1、创建一个Java工程,工程下面新建文件夹lib,在lib中加入Hibernate必须的jar包以及MySql的jar包

2、在src下新建Hibernate的配置文件:hibernate.cfg.xml ,配置信息如下,相关配置介绍见注释:



<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory >
<!-- 配置数据库连接基本信息 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username">root</property>
<property name="connection.password">root123</property>
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
<!-- 配置Hibernate基本信息 -->
<!-- 配置MySQL数据库方言 -->
<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<!-- 控制台是否打印SQL -->
<property name="show_sql">true</property>
<!-- 是否对SQL格式化 -->
<property name="format_sql">true</property>
<!-- 指定自动生成表的策略 -->
<property name="hbm2ddl.auto">update</property>
<!-- 指定关联的hbm.xml文件 -->
<mapping resource="com/elgin/hibernate/model/UserModel.hbm.xml"/>
</session-factory>
</hibernate-configuration>






3. 创建持久化的Java类,Hibernate 不要求持久化类继承任何父类或实现接口,这可以保证代码不被污染。这就是Hibernate被称为低侵入式设计的原因,示例代码如下:




•提供一个无参的构造器:使Hibernate可以使用Constructor.newInstance()来实例化持久化类




•提供一个标识属性(identifier property):通常映射为数据库表的主键字段.如果没有该属性,一些功能将不起作用,如:Session.saveOrUpdate()




•为类的持久化类字段声明访问方法(get/set):Hibernate对JavaBeans风格的属性实行持久化。




•使用非 final类:在运行时生成代理是Hibernate的一个重要的功能.如果持久化类没有实现任何接口,Hibnernate使用CGLIB生成代理.如果使用的是final类,则无法生成CGLIB代理.




•重写 eqauls和hashCode方法:如果需要把持久化类的实例放到Set中(当需要进行关联映射时),则应该重写这两个方法





package com.elgin.hibernate.model;
public class UserModel {
private int id;
private String username;
private String password;
private String phone;
private String email;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public UserModel() {
}
public UserModel(String username, String password, String phone, String email) {
super();
this.username = username;
this.password = password;
this.phone = phone;
this.email = email;
}
@Override
public String toString() {
return "UserModel [id=" + id + ", username=" + username + ", password=" + password + ", phone=" + phone
+ ", email=" + email + "]";
}






4. 创建对象-关系映射文件:UserModel.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">
<!-- Generated 2015-7-15 23:28:28 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<class name="com.elgin.hibernate.model.UserModel" table="USERMODEL">
<id name="id" type="int">
<column name="ID" />
<!-- 主键生成方式,native:使用数据库本地方式 -->
<generator class="native" />
</id>
<property name="username" type="java.lang.String">
<column name="USERNAME" />
</property>
<property name="password" type="java.lang.String">
<column name="PASSWORD" />
</property>
<property name="phone" type="java.lang.String">
<column name="PHONE" />
</property>
<property name="email" type="java.lang.String">
<column name="EMAIL" />
</property>
</class>
</hibernate-mapping>





5. 编写Junit测试类HibernateTest来对Hibernate进行测试:




首先bulidpath,在工程中加入Junit4的类库,方便通过单元测试类对Hibernate进行测试。

package com.elgin.hibernate.test;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
import org.junit.Test;

import com.elgin.hibernate.model.UserModel;

public class HibernateTest {

@Test
public void test(){

//1.创建sessionFactory对象
SessionFactory sessionFactory=null;

//a> 创建Configuraton对象:关联hibernate配置文件和对象映射信息
Configuration configuration=new Configuration().configure();
// 4.0之前这么创建
//sessionFactory=configuration.buildSessionFactory();
//b> 创建一个serviceRegistry对象:hibernate 4.x新添加对象
//   hibernate的任何配置和服务必须要在此对象中注册才能使用
ServiceRegistry serviceRegistry=
new ServiceRegistryBuilder().applySettings(configuration.getProperties())
.buildServiceRegistry();

sessionFactory=configuration.buildSessionFactory(serviceRegistry);
//2.创建一个session对象
Session session=sessionFactory.openSession();
//3.开启事务
Transaction transaction=session.beginTransaction();
//4.执行保存操作
UserModel user=new UserModel("Java", "123qwe", "13626345190", "ddddd@126.com");
session.save(user);
//5.提交事务
transaction.commit();
//6.关闭session
session.close();
//7.关闭sessionFactory
sessionFactory.close();

}
}





结束之后,用Junit Tester 运行,测试成功,并且在控制台打印出如下SQL语句:

Hibernate:
insert
into
USERMODEL
(USERNAME, PASSWORD, PHONE, EMAIL)
values
(?, ?, ?, ?)






打开navicat,可以看到在库hibernate下已经自动生成了表usermodel,打开之后发现存在我们之前存入的数据。


三、过程中出现的问题:

我在开始配置完毕之后,启动之后发现报错,错误信息如下:


ERROR: HHH000388: Unsuccessful: create table USERMODEL (ID integer not null auto_increment, USERNAME varchar(255), PASSWORD varchar(255), PHONE varchar(255),
EMAIL varchar(255), primary key (ID)) type=InnoDB

七月 16, 2015 8:46:55 下午 org.hibernate.tool.hbm2ddl.SchemaUpdate execute

ERROR: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'type=InnoDB'
at line 8


百度之后发现:因为type=InnoDB在5.0以前是可以使用的,但5.1之后就不行了。如果我们把type=InnoDB改为engine=InnoDB就不会有这个问题。但是,我想使用Hibernate,自动帮我建表,怎么办呢。这就与我们指定的数据库方言(dialect)有关了,之前数据库方言的配置是:

<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>

于是将此配置修改为上述配置文件中的配置,即

<property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>

修改之后重新运行,运行正确,生成了表,也插入了数据。

注:Hibernate版本为4.2.5,MySQL为5.6.20




内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: