前言
学习java当然离不开对于java框架的学习了,其中在江湖很有名
ssh(spring+struts2+Hibernate),早想迫不及待的认识他们了,那
么,现在我也记录以下此次学习Hibernate的过程。
什么是Hibernate?
轻量级JavaEE应用的持久层框架,是一个完全的ORM框架。(说完这句话,肯定有很多人懵圈了,下面我来一个个解释)
持久化:将我们想要保存的数据保存到硬盘上,也就是我们电脑的磁盘上,为什么叫持久化呢,就是数据能够保存的很久,所以叫持久化,现在对持久化的实现过程大多通过各种关系型数据库完成,所以我们常说的,将数据保存到数据库中,其实是数据库帮我们帮数据保存到硬盘中了。
持久层:既然知道了什么是持久化,那么持久化层也就应该有点思路了,这里吧数据库看成是内存的一部分,我们就当做将数据保存到数据库中,就保存到了硬盘中一样,所以在操作数据库的或者跟数据库打交道的那一层就是就持久层,比如我们之前知道了三层架构,不就有专门跟数据库打交道的一层叫做持久化层吗
ORM:Object Relational Mapping,对象关系映射,这个是一个思想,模型,或者说是规范。关系数据库中的记录映射成为程序语言中的对象实例,然后通过操作对象,来达到操作数据库的这样一种思想。如果没有ORM思想,我们之前就是直接操作数据库中的记录字段,来达到存储数据的目的。
持久化类:通过上面解释的,持久化类就是可以将类保存到数据库中,并还可以从数据库中拿到该类,这就叫持久化类,也就是下面说到的POJO类
持久化对象:持久化类的实例对象,能保存到数据库中,也能从数据库中取出来。
JPA的概念:Java Persistence API java持久化API,也就是java持久化的规范,ORM就是这JPA中所定义的,它还规定了其它很多规范,JPA维护一个Persistence Context(持久化上下文),这就是这个持久化上下文来事。那些ORM框架都要依据JPA规范来设计,那么各个ORM框架也就度有这么个持久化上下文。持久化上下文大体内容:
1.ORM元数据,JPA支持annotion(注解)或xml两种形式描述对象/关系映射
1. 实体操作API,实现对实体对象的CRUD操作
2. 查询语言,约定了面向对象的查询语言JPQL(javaPersistence Query Language)
接下来,创建第一个Hibernate工程吧。
百度下载 Hibernate相关的包
点击打开网站创建工程并导包
先创建一个普通的java工程,然后解压下载来的Hibernate包,进入lab/required
把包都复制出来到java工程里。配置提示xml提示(自动补全)
在Myeclipse里,点击preferences,之后在左上角搜索xml,找到XML catalog
一栏,点击打开,之后点击右上角的Add
,如图
点击file System
,弹出文件加载框,之后进入Hibernate包的project\hibernate-core\src\main\resources\org\hibernate
目录下,选择hibernate-configuration-4.0.xsd
确定之后,然后key type
选择Schema location
然后直接ok。
第一个是核心xml是配好了,接着配第二个,再点击Add
,之后弹出文件加载框,再添加上面那个目录下的hibernate-mapping-4.0.xsd
,同上Key type:选择,Schema location
然后点确定就好了。提示配置就配置好了,当然,这只是配置了一部分,并不是所有的都会给提示,等到时候用的时候再添加新配置吧,这里配置就先到这里了。列表内容
然后新建一个User类;如下:
public class User {
private int uid;
private String username;
private String password;
private String address;
public int getUid() {
return uid;
}
public void setUid(int uid) {
this.uid = uid;
}
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 getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
之后,再User类所在的包下建立User.hbm.xml
文件
内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.raven.hibernatetest.User" table="t_user">
<!-- 配置实体类id和表id对应 -->
<id name="uid" column="uid">
<!-- 设置数据表id增长策略-->
<!-- native:生成表id值就是主键自动增长 -->
<generator class="native"></generator>
</id>
<property name="username" column="username"></property>
<property name="password" column="password"></property>
<property name="address" column="address"></property>
</class>
</hibernate-mapping>
接着,再src
目录下建立一个xml文件,这里需要注意以下,上面的xml文件是你自己写的,文件名随便起,但是这个xml文件是Hibernate非常重要的配置文件,所以名字必须是,hibernate.cfg.xml
内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///hibernate_day01</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">mimanicaia</property>
<!-- 没有表则创建 -->
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 配置数据库方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
<property name="hibernate.show_sql">true</property>
<mapping resource="com/raven/hibernatetest/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
那么到了最后一步了,写个测试类吧,如下:
public class HibernateDemo {
public static void main(String args[]) {
//第一步 加载hibernate核心配置文件
Configuration cfg = new Configuration();
cfg.configure();
//第二步 创建SessionFactory对象
//这一步 就会自动把表建立好
SessionFactory sessionFactory = cfg.buildSessionFactory();
//第三步 获取session对象
//使用SessionFactory创建session对象
Session session = sessionFactory.openSession();
//第四步 开启事务
Transaction tx = session.beginTransaction();
//第五步 写出相关crud操作
User user = new User();
user.setUid(0);
user.setUsername("谢霆锋");
user.setPassword("123456");
user.setAddress("香港");
session.save(user);
//第六步 提交事务
tx.commit();
session.close();
sessionFactory.close();
}
}
总结:
项目写到这里我发现我的程序运行不起来,但我不知道为什么,明明和视频的代码一模一样啊,为什么嗯?最后在百度的帮助下,我知道了,原来把配置数据库方言那一行注释掉就行,但是我就想着为什么视频没有注释就可以呢?接着我又发现是我数据库的版本的问题,把数据库的方言的值 MySQLInnoDBDialect改为MySQL5InnoDBDialect就可以了。如下:
<!-- 配置数据库方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
这里想说的是,我发的代码已经是正确的了,我已经修正过了,再此记录以下遇到的问题。此次学习就先到这里了