现在做了一个关于hibernate的练习,感觉与写JDBC最不同的地方就是不要写sql,不要再把从数据库中取到的值再一一赋给相应对象,只要填写相应的配置文件就行,这样可以减少掉很多工作。
首先爱你,我们来看下对象关系映射(ORM),它是hibernate的核心设计思想。
下面是应用百度百科的说法:
一般的ORM包括以下四部分:
一个对持久类对象进行CRUD操作的API;
一个语言或API用来规定与类和类属性相关的查询;
一个规定mapping metadata的工具;
一种技术可以让ORM的实现同事务对象一起进行dirty checking, lazy association fetching以及其他的优化操作。
下面梳理下这个流程,首先设置一个配置文件
1.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>
<!--让hb在运行时显示实际的sql语句 -->
<property name="show sql">true</property>
<!--使显示的sql格式化 -->
<property name="format sql">true</property>
<!--设定sql方法,使用的是mysql -->
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<!--JDBC驱动类的名字 -->
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<!--数据库连结串配置 -->
<property name="connection.url">
jdbc:mysql://localhost:3306/xishuizhipan
</property>
<!--数据库用户名 -->
<property name="connection.username">root</property>
<!--数据库密码配置 -->
<property name="connection.password">netjava</property>
<!-- <property name="hbm2ddl.auto">create</property>--><!--自动创建表 -->
</session-factory>
</hibernate-configuration>
2.设定Userinfo的pojo类
private int id;
private String name;
private String psw;
private String signature;
。。。。。set和get方法
3.Userinfo到db的存取,Userinfo.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!-- 指定类到表的映射 -->
<class name="test.pojo.Userinfo" table="userinfo">
<!--主键id的生成机制:native将自动根据数据库生成,mysql是自增长方式 -->
<id name="id" column="id">
<generator class="native"></generator>
</id>
<!--设定Userinfo类每个属性到userinfo表中对应列名的映射 -->
<property name="name" column="name" />
<property name="psw" column="psw"/>
<property name="signature" column="signature"/>
<property name="sex" column="sex"/>
<property name="age" column="age"/>
<property name="birthday" column="birthday"/>
<property name="qq" column="qq"/>
<property name="e_mail" column="e_mail"/>
<property name="phone" column="phone"/>
<property name="occupation" column="occupation"/>
<property name="score" column="score"/>
<property name="graduateSchool" column="graduateSchool"/>
<property name="country" column="country"/>
<property name="province" column="province"/>
<property name="head_path" column="head_path"/>
</class>
</hibernate-mapping>
4.把Userinfo.hbm.xml配置文件配置到hibernate.cfg.xml文件中
<!--指定Userinfo这个pojo类的映射文件路径 -->
<mapping resource="Userinfo.hbm.xml"></mapping>
5.获得hibernate.Session;对象
public class HBUtils {
private static SessionFactory sessionFactory;
//取得根据hibernate.cfg.xml中配置的数据库的一个session对象
//这个session对象类似与java.sql.connection对象;
public static Session getSession(){
return sessionFactory.openSession();
}
//从hibernate.cfg.xml配置中初始化sessionFactory对象
static {
try{
sessionFactory=new Configuration().configure().buildSessionFactory();
}catch(Throwable ex){
throw new ExceptionInInitializerError(ex);
}
}
}
6.编写数据库访问的DAO类
public int saveUserinfo(Userinfo user){
org.hibernate.Session session=HBUtils.getSession();//得到session对象
org.hibernate.Transaction tx=session.beginTransaction();
tx.begin();//取得一个事务对象,开启事务
session.save(user);//保存对象到数据库中
tx.commit();//提交事务
session.close();
return user.getId();
}
经过以上几步,基本就可以用了
7.出错总结
(1)少导入包
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further
details.
原因:少导入slf4j-simple-1.5.8.jar包
值的注意的是slf4j-api是1.6一下的话,slf4j-simple就必须是1.6一下的,不然不支持
(2)配置文件放错地方
Caused by: org.hibernate.HibernateException: /hibernate.cfg.xml
not found
本人把hibernate.cfg.xml
配置文件放在WEB-INF文件下,应该放在src目录下
现阶段学的就这些了,以后有想法再补充