zoukankan      html  css  js  c++  java
  • hibernate基础学习

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

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

    [html] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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

    [java] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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>  
    [java] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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(映射文件)

    [html] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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

    [java] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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>  

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

    [java] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. Configuration cfg = new Configuration().configure();  
    2. SessionFactory factory = cfg.buildSessionFactory();  

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

    HibernateUtils.java

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



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

    Main.java

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




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

  • 相关阅读:
    STL笔记之【map之总概】
    STL笔记之set
    Effective C++笔记之Item49【了解new-handler的行为】
    明成软件条形码打印设置
    将Excel数据导入到SqlServer及导入时数据类型转换失败解决方案
    远程桌面无法复制粘贴传输文件解决办法
    DELPHI如何读取cxcheckcombobox中的值
    Delphi 插入Excel图片和值
    SQL 查询语句先执行 SELECT?
    Linux之xargs命令传递参数的一个过滤器
  • 原文地址:https://www.cnblogs.com/yanqin/p/6013639.html
Copyright © 2011-2022 走看看