zoukankan      html  css  js  c++  java
  • Hibernate简介

    一、基本原理

    Hibernate是一个基于Java的开源的持久化中间件,对JDBC做了轻量的封装。

    采用ORM映射机制,负责实现Java对象和关系数据库之间的映射,把sql语句传给数据库,并且把数据库返回的结果封装成对象。内部封装了JDBC访问数据库的操作,向上层应用提供了面向对象的数据库访问API.

    优点:以对象的形式操作数据,提高开发效率,不用关心数据库种类(换数据库只要修改配值文件)。

    二、使用步骤

        1、创建Hibernate配置文件,存储和数据库连接的相关信息,放在classes下。

    2、创建持久化类(数据bean并实现Serializable接口)

    注意:Serializable接口不是必需的,但是在分布式的系统中,不同的进程之间传输时需要实现这个接口。

    POJO(Plain Ordinary Java Object) 就是Value Object。

        3、创建对象-关系-映射文件(ORM  Object Relational Map)

        4、编写使用Hibernate API访问数据库的代码。

    三、Eclipse中配置Hibernate

    四、创建映射文件

    使用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">

    <hibernate-mapping>

    <class name="com.huayu.Users" table="[users]" schema="dbo" catalog="test">

    <!—自动增长的主键映射-->

            <id name="id" type="integer">

                <column name="id" />

                <generator class="native" />

            </id>

            <!—其它属性映射-->

            <property name="name" type="string">

                <column name="name" length="20" not-null="true" />

            </property>

        </class>

    </hibernate-mapping>

        五、HQL(Hibernate Query Language)

    1、 添加

    Configuration cfg = new Configuration();

    Configuration c = cfg.configure();

    SessionFactory sf = c.buildSessionFactory();

    Session sess = sf.openSession();   

    Transaction tx=null;

    try {

         tx = sess.beginTransaction();

         Users u = new Users();

         u.setName("bbb");

         sess.save(u);

         tx.commit();

    }

    catch (Exception e) {

    if (tx!=null) tx.rollback();

         e.printStackTrace();

    }

    finally {

         sess.close();

    }

    2、 查询

    a)   所有对象

    from User 注意User大写

    或者

    select u from Users as u

    b)        条件查询

    from Users as u where id=’1’

    c)         模糊查询

    String name=”abc”;

    String username=”%”+name+”%”;

    Query q = sess.createQuery(“from Users as u where u.username like :key”);

    q.setparameter(“key”,username);

    或者

    String sql = "from News as n where title like '%"+title+"%'";

    d)        例子:

    Transaction tx=null;

    try {

    tx = sess.beginTransaction();

    String sql = "from Users";

    Query query = sess.createQuery(sql);

    List list = query.list();

    Iterator it = list.iterator();

    while(it.hasNext())

    {

    Users u = (Users)it.next();

    System.out.println("id="+u.getId()+"  name="+u.getName());

    }

    tx.commit();

    }

    catch (Exception e) {

    if (tx!=null) tx.rollback();

       e.printStackTrace();

    }

    finally {

    sess.close();

    }

    3、   更新

    session.update(user)

    4、  删除

    session.delete(user);

    5、   通用jdbc查询

    Connection conn = session.connection();//建立到数据库的连接

    PreparedStatement ps = conn.prepareStatement(sql);

    ……

    ……

    其它和以前编程一样

    六、Hibernate中jar包简介(了解)

    必选包:

    Hibernate3.jar:

      Hibernate的库,必须使用的jar包

      cglib-asm.jar:

      CGLIB库,Hibernate用它来实现PO字节码的动态生成,非常核心的库,必须使用的jar包

      dom4j.jar:

      dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个非常非常优秀的Java XML API,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。在IBM developerWorks上面可以找到一篇文章,对主流的Java XML API进行的性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。我早在将近两年之前就开始使用dom4j,直到现在。如今你可以看到越来越多的Java软件都在使用dom4j来读写XML,特别值得一提的是连Sun的JAXM也在用dom4j。这是必须使用的jar包, Hibernate用它来读写配置文件。

      odmg.jar:

      ODMG是一个ORM的规范,Hibernate实现了ODMG规范,这是一个核心的库,必须使用的jar包。

      commons-collections.jar:

      Apache Commons包中的一个,包含了一些Apache开发的集合类,功能比java.util.*强大。必须使用的jar包。

      commons-beanutils.jar:

      Apache Commons包中的一个,包含了一些Bean工具类类。必须使用的jar包。

      commons-lang.jar:

      Apache Commons包中的一个,包含了一些数据类型工具类,是java.lang.*的扩展。必须使用的jar包。

      commons-logging.jar:

      Apache Commons包中的一个,包含了日志功能,必须使用的jar包。这个包本身包含了一个Simple Logger,但是功能很弱。在运行的时候它会先在CLASSPATH找log4j,如果有,就使用log4j,如果没有,就找JDK1.4带的 java.util.logging,如果也找不到就用Simple Logger。commons-logging.jar的出现是一个历史的的遗留的遗憾,当初Apache极力游说Sun把log4j加入JDK1.4,然而JDK1.4项目小组已经接近发布JDK1.4产品的时间了,因此拒绝了Apache的要求,使用自己的java.util.logging,这个包的功能比log4j差的很远,性能也一般。

      后来Apache就开发出来了commons-logging.jar用来兼容两个 logger。因此用commons-logging.jar写的log程序,底层的Logger是可以切换的,你可以选择log4j, java.util.logging或者它自带的Simple Logger。不过我仍然强烈建议使用log4j,因为log4j性能很高,log输出信息时间几乎等于System.out,而处理一条log平均只需要5us。你可以在Hibernate的src目录下找到Hibernate已经为你准备好了的log4j的配置文件,你只需要到Apache 网站去下载log4j就可以了。commons-logging.jar也是必须的jar包。

    可选包:

      ant.jar:

      Ant编译工具的jar包,用来编译Hibernate源代码的。如果你不准备修改和编译Hibernate源代码,那么就没有什么用,可选的jar包

      optional.jar:

      Ant的一个辅助包。

      c3p0.jar:

      C3PO是一个数据库连接池,Hibernate可以配置为使用C3PO连接池。如果你准备用这个连接池,就需要这个jar包。

      proxool.jar:

      也是一个连接池,同上。

      commons-pool.jar, commons-dbcp.jar:

      DBCP数据库连接池,Apache的Jakarta组织开发的,Tomcat4的连接池也是DBCP。

      实际上Hibernate自己也实现了一个非常非常简单的数据库连接池,加上上面3个,你实际上可以在Hibernate上选择4种不同的数据库连接池,选择哪一个看个人的偏好,不过DBCP可能更通用一些。另外强调一点,如果在EJB中使用Hibernate,一定要用App Server的连接池,不要用以上4种连接池,否则容器管理事务不起作用。

      connector.jar:

      JCA 规范,如果你在App Server上把Hibernate配置为Connector的话,就需要这个jar。不过实际上一般App Server肯定会带上这个包,所以实际上是多余的包。

      jaas.jar:

      JAAS是用来进行权限验证的,已经包含在JDK1.4里面了。所以实际上是多余的包。

      jcs.jar:

      如果你准备在Hibernate中使用JCS的话,那么必须包括它,否则就不用。

      jdbc2_0-stdext.jar:

      JDBC2.0的扩展包,一般来说数据库连接池会用上它。不过App Server都会带上,所以也是多余的。

      jta.jar:

      JTA规范,当Hibernate使用JTA的时候需要,不过App Server都会带上,所以也是多余的。

      junit.jar:

      Junit包,当你运行Hibernate自带的测试代码的时候需要,否则就不用。

      xalan.jar, xerces.jar, xml-apis.jar:

      Xerces是XML解析器,Xalan是格式化器,xml-apis实际上是JAXP。一般App Server都会带上,JDK1.4也包含了解析器,不过不是Xerces,是Crimson,效率比较差,不过Hibernate用XML只不过是读取配置文件,性能没什么紧要的,所以也是多余的

    主键生成方式

     (1)native

    由Hibernate根据底层数据库自行判断采用identity、hilo、sequence

    其中一种作为主键生成方式

     (2) uuid.hex

    由Hibernate基于128 位唯一值产生算法生成16 进制数值(编码后

    以长度32 的字符串表示)作为主键。

     (3) Assigned

             主键由外部程序负责生成,无需Hibernate参与。

  • 相关阅读:
    (译)linux系统关于命令echo的15个例子
    linux之grep实例讲解
    linux grep练习
    (译)"usermod"命令使用完全指导---15个练习例程截图
    linux分区,文件系统,目录结构概述
    Linux 配置YUM
    Linux 强制安装rpm 包
    $LANG、$NLS_LANG 记录一下
    Oracle性能诊断艺术-相关脚本说明
    datafile相关(add、rename、drop)
  • 原文地址:https://www.cnblogs.com/linzheng/p/1924847.html
Copyright © 2011-2022 走看看