转载自:http://blog.csdn.net/fb281906011/article/details/17628111

一:下载hibernate:http://hibernate.org/orm/downloads/并且进行解压,里面有个lib文件夹,里面全是Hibernate所依赖的jar包,当然,不能缺少的核心包hibernate3.jar(这里我用到的是hibernate3),至于和现在的hibernate4有啥区别,自己也不清楚(希望有大牛能给我指正);
二:jar包都准备好后,就可以新建一个Javaproject,将刚才的的jar包全部导入(当然可能不是所有jar包都需要,但是本屌也不清楚哪些可以不要,为了以防万一,都进行导入,安全起见嘛);
三:工程建好后,我们就可以来进行我们的开发练习咯:
首先,我们先在src目录下新建一个hibernate.cfg.xml文件(至于为啥在src目录下,因为src目录最终会编译到一个bin文件夹中也就是类路径下(classpath下面),服务器启动时会自己在classpath下寻找该文件进行解析加载进来);
其次,就开始进行对hibernate.cfg.xml文件配置进行讲解(我连接的是MySQL5数据库,这里必须将MySQL-connector-Java.jar驱动包导入):

  1. <span style="font-size:14px;"><hibernate-configuration>
  2. <session-factory>
  3. <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property><!-- mysql驱动 -->
  4. <property name="hibernate.connection.url">jdbc:mysql:///test</property><!-- mysql默认连接数据库test以及默认端口3306 -->
  5. <property name="hibernate.connection.username">root</property><!-- 用户名 -->
  6. <property name="hibernate.connection.password">root</property><!-- 密码 -->
  7. <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property><!-- mysql方言 -->
  8. <property name="hbm2ddl.auto">create</property><!-- 更新数据库方式 -->
  9. <property name="show_sql">true</property><!-- 是否后台打印语句 -->
  10. <mapping resource="toone/com/cn/bo/User.hbm.xml"/><!--映射文件-->
  11. </session-factory>
  12. </hibernate-configuration></span>

以上属性(property)我们都可以在之前下载的Hibernate解压包中的etc文件夹下的hibernate.properties文件中找到()。这里对hbm2ddl.auto进行说明一下(有四个值):

create:每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
create-drop :每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。
update:最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据 model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等应用第一次运行起来后才会。
validate::启动时验证现有schema与你配置的hibernate是否一致,如果不一致就抛出异常,并不做更新。

四:接下来我们就可以来进行我们的实体开发了:

User.java

  1. <span style="font-size:14px;">package toone.com.cn.bo;
  2. import java.util.Date;
  3. public class User {
  4. private int id;//必须有主键,因为hibernate很多方法都需要用到主键id
  5. private String name;
  6. private Date birthday;//必须提供默认的构造方法,这里没有,但是所有类都带有默认的构造方法;</span>
  1. <span style="font-size:14px;">  public int getId() {
  2. return id;
  3. }
  4. public void setId(int id) {
  5. this.id = id;
  6. }
  7. public String getName() {
  8. return name;
  9. }
  10. public void setName(String name) {
  11. this.name = name;
  12. }
  13. public Date getBirthday() {
  14. return birthday;
  15. }
  16. public void setBirthday(Date birthday) {
  17. this.birthday = birthday;
  18. }
  19. }</span><span style="font-size: 24px;">
  20. </span>

User.hbm.xml(映射文件)

  1. <span style="font-size:14px;"><hibernate-mapping package="toone.com.cn.bo.domain">
  2. <class name="User" table="user"><!--这里的table值对应数据库中的表名;如果没有table值,默认等于类名小写 -->
  3. <id name="id" column="id">
  4. <generator class="native"></generator><!--采用主键自增长方式-->
  5. </id>
  6. <property name="name" column="name"/><!-- 这里的column值对应数据库中的属性名;如果没有column值,默认等于属性名 -->
  7. <property name="birthday" column="birthday"/>
  8. </class>
  9. </hibernate-mapping></span>

五:最后我们就可以来进行我们的业务开发了(主要进行user的增删改查操作):

以前的采用jdbc来进行连接数据库的方式是很烦琐的,这里就充分发挥了hibernate的方便与优势了:

Main.java

  1. <span style="font-size:14px;">package toone.com.cn;
  2. import java.util.Date;
  3. import org.hibernate.HibernateException;
  4. import org.hibernate.Session;
  5. import org.hibernate.SessionFactory;
  6. import org.hibernate.Transaction;
  7. import org.hibernate.cfg.Configuration;
  8. import toone.com.cn.bo.User;
  9. public class Main {
  10. public static void main(String[] args){
  11. //这里千万注意,不能写成Configuration cfg = new Configuration();否则会报Hibernate Dialect must be explicitly set 错误信息将我们误导
  12. //;实际上前面我们已经配置了mysql的方言;
  13. Configuration cfg = new Configuration().configure();//对于configure()方法,我们可以引入其源代码进行查看,其会在类路
  14. //径下自动去加载一个默认的hibernate.cfg.xml文件;如果我们想换其他名字,可以使用其重载方法,具体可以查看其源代码(下载的压缩包中有)
  15. SessionFactory factory = cfg.buildSessionFactory();
  16. User user = new User();
  17. user.setName("Kobi");
  18. user.setBirthday(new Date());
  19. Session session = null;
  20. Transaction tx = null;
  21. try {
  22. session = factory.openSession();
  23. tx = session.beginTransaction();//开启事务
  24. session.save(user);//进行保存
  25. tx.commit();//提交事务
  26. } catch (HibernateException e) {
  27. if(tx!=null){
  28. tx.rollback();//回滚事务
  29. }
  30. throw e;//必须抛出异常
  31. }finally{
  32. if(session!=null){
  33. session.close();//关闭session
  34. }
  35. }
  36. }
  37. }</span>

好了,一个添加功能就已经实现,但是写到这里,我们可能发现我们每进行一次操作,比如添加,修改,删除,查找都需要执行这段代码:

  1. Configuration cfg = new Configuration().configure();
  2. SessionFactory factory = cfg.buildSessionFactory();

这段代码非常耗性能,因为它每次都需要去加载解析配置文件hibernate.cfg.xml,并且每次都需要创建session;因此我们不妨自己创建一个工具类,采用单利的方式来进行实现,并且该工具类实现实体的增删改查,代码如下:

HibernateUtils.java

  1. <span style="font-size:14px;">package toone.com.cn.util;
  2. import java.io.Serializable;
  3. import org.hibernate.HibernateException;
  4. import org.hibernate.Session;
  5. import org.hibernate.SessionFactory;
  6. import org.hibernate.Transaction;
  7. import org.hibernate.cfg.Configuration;
  8. public class HibernateUtils {
  9. private static SessionFactory sessionfactory;
  10. private HibernateUtils(){}
  11. static{
  12. Configuration cfg = new Configuration().configure();
  13. sessionfactory = cfg.buildSessionFactory();
  14. }
  15. public static Session getSession(){
  16. return sessionfactory.openSession();
  17. }
  18. //添加
  19. public static void add(Object obj){
  20. Session session = null;
  21. Transaction tx = null;
  22. try {
  23. session = HibernateUtils.getSession();
  24. tx = session.beginTransaction();
  25. session.save(obj);//区别:save()方法如果没有开启事务,它会执行一条插入语句,但之后由于没有提交事务,它又进行
  26. //session.persist(obj);//回滚了,而persist()方法在没有开启事务的时候,它根本不会去执行,即没有那条插入语句
  27. tx.commit();
  28. }finally{
  29. if(session!=null){
  30. session.close();
  31. }
  32. }
  33. }
  34. //修改
  35. public static void update(Object obj){
  36. Session session = null;
  37. Transaction tx = null;
  38. try {
  39. session = HibernateUtils.getSession();
  40. tx = session.beginTransaction();
  41. session.update(obj);
  42. tx.commit();
  43. }finally{
  44. if(session!=null){
  45. session.close();
  46. }
  47. }
  48. }
  49. //删除
  50. public static void delete(Object obj){
  51. Session session = null;
  52. Transaction tx = null;
  53. try {
  54. session = HibernateUtils.getSession();
  55. tx = session.beginTransaction();
  56. session.delete(obj);
  57. tx.commit();
  58. }finally{
  59. if(session!=null){
  60. session.close();
  61. }
  62. }
  63. }
  64. //查找 不需要开启事务
  65. public static Object findById(Class clazz,Serializable id){
  66. Session session = null;
  67. try {
  68. session = HibernateUtils.getSession();
  69. //这里需要区分一下get()与load()的区别,load()不会立即//去访问数据库只有在第一次使用的时候才会去加载(懒加载);
  70. //load方法永远不可能返回空对象(如果不存在,其会产生一个user的子类)具体可以去查资料区别这两个方法
  71. //Object obj = session.load(clazz, id);
  72. Object obj = session.get(clazz, id);return obj;}finally{if(session!=null){session.close();}}}}
  73. </span>

最后,一个实体的增删改查操作就完成了,下面我们可以重写Main.java文件来使用HibernateUtils工具类来对实体进行操作了:

Main.java

  1. <span style="font-size:14px;">package toone.com.cn;
  2. import java.util.Date;
  3. import toone.com.cn.bo.User;
  4. import toone.com.cn.util.HibernateUtils;
  5. public class Main {
  6. public static void main(String[] args){
  7. User user = new User();
  8. user.setName("Kobi");
  9. user.setBirthday(new Date());
  10. HibernateUtils.add(user);//添加
  11. user.setName("Jams");
  12. HibernateUtils.update(user);//修改
  13. HibernateUtils.delete(user);//删除
  14. User user1 = (User) HibernateUtils.findById(User.class, user.getId());//查找
  15. System.out.println(user1.getName());
  16. }
  17. }</span>

总结:了解了Hibernate的基本作用,学会了使用其来进行增删改查操作,算是工作之余的一点收获吧,以后还得继续坚持发帖,不断学习!

hibernate基础学习的更多相关文章

  1. Hibernate基础学习2

    Hibernate基础学习2 测试hibernate的一级缓存,事务以及查询语句 1)Hibernate的一些相关概念 hibernate的一级缓存 1)缓存是为了提高该框架对数据库的查询速度 2)一 ...

  2. Hibernate基础学习(五)—对象-关系映射(下)

    一.单向n-1 单向n-1关联只需从n的一端可以访问1的一端. 域模型: 从Order到Customer的多对一单向关联.Order类中定义一个Customer属性,而在Customer类不用存放Or ...

  3. Hibernate基础学习(四)—对象-关系映射(上)

    一.映射对象标识符      Java语言按内存地址来识别或区分同一个类的不同对象,而关系数据库按主键值来识别或区分同一个表的不同记录.Hibernate使用对象标识符(OID)来建立内存中的对象和数 ...

  4. Hibernate基础学习(七)—检索方式

    一.概述      Hibernate有五种检索方式. 1.导航对象图检索方式      根据已经加载的对象,导航到其他对象. Order order = (Order)session.get(Ord ...

  5. Hibernate基础学习(六)—Hibernate二级缓存

    一.概述      Session的缓存是一块内存空间,在这个内存空间存放了相互关联的Java对象,这个位于Session缓存内的对象也被称为持久化对象,Session负责根据持久化对象的状态来同步更 ...

  6. Hibernate基础学习(三)—Session

    一.概述      Session接口是Hibernate向应用程序提供的操纵数据库最主要的接口,它提供了基本的保存.更新.删除和加载Java对象的方法.      Session具有一个缓存,位于缓 ...

  7. Hibernate基础学习(二)—Hibernate相关API介绍

    一.Hibernate的核心接口      所有的Hibernate应用中都会访问Hibernate的5个核心接口.      (1)Configuration接口: 配置Hibernate,启动Hi ...

  8. Hibernate基础学习(一)—初识Hibernate

    一.对象的持久化 狭义的理解: 持久化仅仅指把对象永久的保存到数据库中. 广义的理解: 持久化包括和数据库相关的各种操作.         保存: 把对象永久保存到数据库中.         更新: ...

  9. hibernate基础学习---hierbnate2级缓存

    1:开启二级缓存sessionFactory需要安装jar包 2:在实体类配置文件添加(配置二级缓存).我的配置文件是Account.hbm.xml <?xml version="1. ...

随机推荐

  1. 容器基础(八): 使用docker swarm部署程序

    环境 基于上一节的env/server:v0.1, env/worker:v0.1镜像, 在基于debian8.2的两台机器上测试部署docker swarm. docker service部署 ➜ ...

  2. BZOJ 2946 POI2000 公共串 后缀自动机(多串最长公共子串)

    题意概述:给出N个字符串,每个串的长度<=2000(雾...可能是当年的年代太久远机子太差了),问这N个字符串的最长公共子串长度为多少.(N<=5) 抛开数据结构,先想想朴素做法. 设计一 ...

  3. POJ 1703 Find them, Catch them(并查集拓展)

    Description The police office in Tadu City decides to say ends to the chaos, as launch actions to ro ...

  4. Linux 监测系统资源

    Top;1; Linux监控磁盘性能 yum install sysstat iostat -x 1 %util:磁盘使用io所占百分比

  5. js把字符串格式的时间转换成几秒前、几分钟前、几小时前、几天前等格式

    最近在做项目的时候,需要把后台返回的时间转换成几秒前.几分钟前.几小时前.几天前等的格式:后台返回的时间格式为:2015-07-30 09:36:10,需要根据当前的时间与返回的时间进行对比,最后显示 ...

  6. 【心情】HNOI2018游记

    Day 0. 全机房的人好像都在做题.然而下午是社团节的游园会,身为社干的我风风雨雨在外面各种搬凳子搬椅子换场地招待外校同学……就这样我好像什么都没有复习. 晚上就一起去酒店了.大概因为是高一的缘故, ...

  7. [SCOI2010]序列操作 线段树

    ---题面--- 题解: 在考场上打的这道题,出人意料的很快就打完了?! 直接用线段树,维护几个东西: 1,lazy标记 : 表示区间赋值 2,mark标记:表示区间翻转 3,l1:前缀最长连续的1的 ...

  8. hdu 6200 mustedge mustedge(并查集+树状数组 或者 LCT 缩点)

    hdu 6200 mustedge mustedge(并查集+树状数组 或者 LCT 缩点) 题意: 给一张无向连通图,有两种操作 1 u v 加一条边(u,v) 2 u v 计算u到v路径上桥的个数 ...

  9. [COGS 1535] [ZJOI2004]树的果实 树状数组+桶

    我们用树状数组做差就可以解决一切问题,我用桶排并用此来表示出第几大就可以直接求前缀和了 #include<cstdio> #include<algorithm> #define ...

  10. E. Intercity Travelling

    E. Intercity Travelling time limit per test 1.5 seconds memory limit per test 256 megabytes input st ...