从昨天晚上开始看王勇老师的hibernate学习视频,跟着做了一个小程序,大体的对hibernate有了一个理解,下面我就简述一下自己的学习心得。毕竟刚开始接触要说出其实质还是有困难的,
1.首先是hibernate环境的搭建。
以前用struts的时候是直接在项目里添加jar包,因为hibernate要引入的jar包比较多,所以采用这种方法就比较麻烦,这里我们采用的是创建一个User Library的方式,把搭建hibernate所需要的jar包全部导入到一个库里面,
jar包包括:hibernate_home/hibernate.jar, hibernate_home/*.jar ,还有对应的数据库驱动。
库创建后我们再从项目里添加这个User Library。
2.hibernate的配置文件
它有.xml的,也有.properties的,这里我们使用xml的,只需要将那个etc目录下的hibernate.cfg.xml拷贝到src文件夹下。然后根据你要使用的数据库对照着hibernate.properties里面相应的描述配置hibernate.xml。需要配置内容的大同小异,无非就是url,驱动,还有用户名和密码,另外还有一个适配器(我暂时还不明白它的用处,好像是因为有了它移植性变得更好了)
3.写一个User类,这就是我们要导入数据库的一条数据对象。
这个User没有继承任何hibernate的类,当我们不适用hibernate框架的时候它还可以继续使用,这说明hibernate是没有侵入性的。另外还要配置这个User对应的一个配置文件,名字可以随便取,但是我们遵从一定得规范,可以写成User.hbm.xml,这个我们可以从eg/org/hibernate/auction中拷贝一个文件。理论上这个文件可以拷贝到任意目录下,但是遵从规范我们把它拷贝到User同级的目录下。进行配置,把User的属性都配置到里面去。
4.将我们的User.hbm.xml在hibernate.cfg.xml中进行配置,用<mapping resource="com/mj/hibernate/User.hbm.xml"/>注意是用/隔开而不是用逗点.
5.写一个工具类,用它来建立相应的表。
我们取名为ExportDB
大体的步骤是,它要用到几个Hibernate类
首先是创建一个Configuration类,Configurationg cfg = new Configuration().configure();
这里需要注意的是由于默认的配置文件是.properties的,这里我们就要加一个.configure()方法,改成.xml的,它其实就是对应我们的Hibernate.cfg.xml文件。
然后在创建一个SchemaExport类,SchemaExport se = new SchemaExport(cfg);这个类我还不知道是干什么用的,先记着吧,呵呵。。。好像就是它把那个配置文件配置的信息,在数据库中导入了一个表。
接着就是执行了,se.create(true,true);
参数忘了是干吗用的了,就这样就能创建一个表了。
6.下一个客户端类,用它来添加记录。
首先也是创建一个Configuration类,Configuration cfg = new Configuration().configure();
然后是创建一个SessionFactory类,SessionFactory sf = cfg.buildSessionFactory();
接着就是一个Session类,这里是要包围在一个try catch里面的,累了,我要洗澡了,不想写了,就把所有的源码提一下吧,嘿嘿,自己写给自己的。。。
ExportDB类:
package com.mj.hibernate;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
public class ExportDB {
public static void main(String []args){
Configuration cfg = new Configuration().configure();
SchemaExport se = new SchemaExport(cfg);
se.create(true, true);
}
}
Client类:
package com.mj.hibernate;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class Client {
public static void main(String[] args) {
Configuration cfg = new Configuration().configure();
SessionFactory sf = cfg.buildSessionFactory();
Session session = null;
try {
session = sf.openSession();
session.beginTransaction();
User user = new User();
user.setUserName("wangmaojian");
user.setPassword("wangmaojianggege");
user.setGender("boy");
user.setCreateTime(new Date());
session.save(user);
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
if (session != null){
if (session.isOpen()){
session.close();
}
}
}
}
}
1.首先是hibernate环境的搭建。
以前用struts的时候是直接在项目里添加jar包,因为hibernate要引入的jar包比较多,所以采用这种方法就比较麻烦,这里我们采用的是创建一个User Library的方式,把搭建hibernate所需要的jar包全部导入到一个库里面,
jar包包括:hibernate_home/hibernate.jar, hibernate_home/*.jar ,还有对应的数据库驱动。
库创建后我们再从项目里添加这个User Library。
2.hibernate的配置文件
它有.xml的,也有.properties的,这里我们使用xml的,只需要将那个etc目录下的hibernate.cfg.xml拷贝到src文件夹下。然后根据你要使用的数据库对照着hibernate.properties里面相应的描述配置hibernate.xml。需要配置内容的大同小异,无非就是url,驱动,还有用户名和密码,另外还有一个适配器(我暂时还不明白它的用处,好像是因为有了它移植性变得更好了)
3.写一个User类,这就是我们要导入数据库的一条数据对象。
这个User没有继承任何hibernate的类,当我们不适用hibernate框架的时候它还可以继续使用,这说明hibernate是没有侵入性的。另外还要配置这个User对应的一个配置文件,名字可以随便取,但是我们遵从一定得规范,可以写成User.hbm.xml,这个我们可以从eg/org/hibernate/auction中拷贝一个文件。理论上这个文件可以拷贝到任意目录下,但是遵从规范我们把它拷贝到User同级的目录下。进行配置,把User的属性都配置到里面去。
4.将我们的User.hbm.xml在hibernate.cfg.xml中进行配置,用<mapping resource="com/mj/hibernate/User.hbm.xml"/>注意是用/隔开而不是用逗点.
5.写一个工具类,用它来建立相应的表。
我们取名为ExportDB
大体的步骤是,它要用到几个Hibernate类
首先是创建一个Configuration类,Configurationg cfg = new Configuration().configure();
这里需要注意的是由于默认的配置文件是.properties的,这里我们就要加一个.configure()方法,改成.xml的,它其实就是对应我们的Hibernate.cfg.xml文件。
然后在创建一个SchemaExport类,SchemaExport se = new SchemaExport(cfg);这个类我还不知道是干什么用的,先记着吧,呵呵。。。好像就是它把那个配置文件配置的信息,在数据库中导入了一个表。
接着就是执行了,se.create(true,true);
参数忘了是干吗用的了,就这样就能创建一个表了。
6.下一个客户端类,用它来添加记录。
首先也是创建一个Configuration类,Configuration cfg = new Configuration().configure();
然后是创建一个SessionFactory类,SessionFactory sf = cfg.buildSessionFactory();
接着就是一个Session类,这里是要包围在一个try catch里面的,累了,我要洗澡了,不想写了,就把所有的源码提一下吧,嘿嘿,自己写给自己的。。。
ExportDB类:
package com.mj.hibernate;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
public class ExportDB {
public static void main(String []args){
Configuration cfg = new Configuration().configure();
SchemaExport se = new SchemaExport(cfg);
se.create(true, true);
}
}
Client类:
package com.mj.hibernate;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class Client {
public static void main(String[] args) {
Configuration cfg = new Configuration().configure();
SessionFactory sf = cfg.buildSessionFactory();
Session session = null;
try {
session = sf.openSession();
session.beginTransaction();
User user = new User();
user.setUserName("wangmaojian");
user.setPassword("wangmaojianggege");
user.setGender("boy");
user.setCreateTime(new Date());
session.save(user);
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
if (session != null){
if (session.isOpen()){
session.close();
}
}
}
}
}