第四步 hibernate整合
1.调整代码结构,增加数据库操作服务及接口
位置:
代码:
UserDao.java
package com.djl.dao;
import java.util.List;
import com.djl.entity.User;
public interface UserDao {
void add(User user);
void delete(User user);
void update(User user);
User findByName(String username);
List<User> findAll();
}
HibernateDao.java
package com.djl.daoImpl;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import com.djl.dao.UserDao;
import com.djl.entity.User;
public class HibernateDao implements UserDao {
SessionFactory sessionFactory;
@Override
public void add(User user) {
Session session = sessionFactory.openSession();
Transaction transaction = session.beginTransaction();
session.save(user);
transaction.commit();
session.close();
}
@Override
public void delete(User user) {
}
@Override
public void update(User user) {
}
@Override
public User findByName(String username) {
return null;
}
@Override
public List<User> findAll() {
return null;
}
public SessionFactory getSessionFactory() {
return sessionFactory;
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
}
UserStorage.java被调整为:
package com.djl.serviceImpl;
import com.djl.dao.UserDao;
import com.djl.entity.User;
import com.djl.service.UserService;
public class UserStorage implements UserService {
UserDao userDao;
@Override
public void addUser(User user) {
if(userDao != null){
userDao.add(user);
}
else{
System.out.println("Error: userDao is null!");
}
}
public UserDao getUserDao() {
return userDao;
}
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
}
2.加载Hiberante的jar包到lib中。
这各部分存在不同,这里边有多个lib可以选择,因此首先引入的是应该是所有的Reqiured库。
3.编写hibernate.cfg.xml配置文件和User.hbm.xml映射文件
位置:
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://localhost:3306/hibernate</property>
<!-- 数据库用户名称 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库密码 -->
<property name="connection.password">12345678</property>
<!-- 设置数据库连接池默认个数 -->
<property name="connection.pool_size">1</property>
<!-- 设置数据库SQL语言类型 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 设置是否显示SQL语句-->
<property name="show_sql">true</property>
<!-- 设置是否格式化SQL语句 -->
<property name="format_sql">true</property>
<!-- 设置使用线程-->
<property name="current_session_context_class">thread</property>
<property name="hbm2ddl.auto">create</property>
<!-- 设置hibernate的映射文件-->
<mapping resource="com/djl/entity/User.hbm.xml"/>
</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">
<!-- Generated 2016-12-20 14:07:08 by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<class name="com.djl.entity.User" table="USER">
<id name="uid" type="int">
<column name="UID" />
<generator class="assigned" />
</id>
<property name="username" type="java.lang.String">
<column name="USERNAME" />
</property>
<property name="password" type="java.lang.String">
<column name="PASSWORD" />
</property>
</class>
</hibernate-mapping>
4.修改HibernateDao.java引入sessionFactory进行控制。
5.修改spring的容器配置文件root-context.xml实现hibernate中sessionFactory的依赖注入。
编译程序发生错误:
错误的意思是说,没有找到mysql的JDBC驱动。因此需要添加Mysql的驱动,即:mysql-connector-java-5.1.40-bin.jar
注意:mysql-connector-java-6.0.3.jar,曾经添加了这个jar包,但是出现了兼容性错误,是因为这个需要JDK1.8才可以。除此意外,还有hibernate-release-5.1.3.Final,这个版本的hibernate,也需要JDK1.8才能够实现支持。我们的环境是JDK1.7,因此配置框架,一定要注意版本信息。