zoukankan      html  css  js  c++  java
  • JavaEE笔记(一)

    Hibernate

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。

    Hibernate核心API

      Session

    Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句)。但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。

    SessionFactory

    SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。

    Transaction

    Transaction 接口是一个可选的API,可以选择不使用这个接口,取而代之的是Hibernate 的设计者自己写的底层事务处理代码。 Transaction 接口是对实际事务实现的一个抽象,这些实现包括JDBC的事务、JTA 中的UserTransaction、甚至可以是CORBA 事务。之所以这样设计是能让开发者能够使用一个统一事务的操作界面,使得自己的项目可以在不同的环境和容器之间方便地移植。

    Query

    Query接口让你方便地对数据库及持久对象进行查询,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作。

    Criteria

    Criteria接口与Query接口非常类似,允许创建并执行面向对象的标准化查询。值得注意的是Criteria接口也是轻量级的,它不能在Session之外使用。

    Configuration

    Configuration 类的作用是对Hibernate 进行配置,以及对它进行启动。在Hibernate 的启动过程中,Configuration 类的实例首先定位映射文档的位置,读取这些配置,然后创建一个SessionFactory对象。虽然Configuration 类在整个Hibernate 项目中只扮演着一个很小的角色,但它是启动hibernate 时所遇到的第一个对象。

    ORM(Object Relational Mapping)

    对象关系映射,是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的--“虚拟对象数据库”。

    Hibernate配置文件

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
    
    <hibernate-configuration>
      <session-factory>
        <!-- 配置方言  告诉hibernate 是使用哪种类型的数据库  -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
        <!-- 配置mysql的驱动 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <!-- 配置mysql的url 注意不要空格  -->
        <property name="connection.url">jdbc:mysql://127.0.0.1:3306/jg33</property>
        <!-- 配置用户名 -->
        <property name="connection.username">root</property> 
           <!-- 配置数据库密码 -->
           <property name="connection.password">root</property>
           <!-- 配置显示sql语句 -->
           <property name="show_sql">true</property>
           <!-- 格式化sql语句 -->
           <property name="format_sql">true</property>
           <!-- 配置自动创建表 -->
        <!-- 内涵4个参数
            create:创建,但是如果有表则会删除表,表示无论以前是否有表都会删除以前的表,每次运行都是如此;
            delete:删除表;
            create-drop:加载hibernate时创建,退出是删除表结构;
            update:有表则不管,执行操作,没有则创建表 -->
    <property name="hbm2ddl.auto">create</property> <!-- 映射orm的xml student.hbm.xml --> <!-- <mapping resource="com/my/cfg/student.hbm.xml"/> --> <mapping class="com.my.bean.User"/> </session-factory> </hibernate-configuration>

    创建关系映射文件

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-mapping PUBLIC 
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
    <!--package 对包文件进行映射   -->
    <hibernate-mapping package="com.my.bean">
    <!--对哪个实体bean进行映射  name必须对应的类的名字  table对应你要映射的表名 -->
        <!--  table和 column 可以省略,默认:表对应类名, 列名:对应对象属性-->
        <class name="Student" table="t_student">
            <!--对应的标识符, id对应属性的id(标识符) type 可选择项-->
            <id name="id" column="sid" type="java.lang.Integer">
                <!--配置主键的生成策略  hibernate自动增长id -->
                <generator class="increment"></generator>
            </id>
            <property name="name" column="name" type="java.lang.String" ></property>
            <property name="birthday" column="birthday"></property>
        </class>
    </hibernate-mapping>    

    事务处理

    事务是一组组合成逻辑工作单元的数据库操作,在系统执行过程中可能会出错,但事务将控制和维护每个数据库的一致性和完整性。事务处理的主要特征是,任务要么全部 完成,要么都不完成。在写入一些记录时,要么写入所有记录,要么什么都不写入。如果在写入一个记录时出现了一个失败,那么在事务处理中已写入的其他数据就 会回滚。

    1)数据库上锁:LOCK TABLES tablename WRITE;(多个用户同时操作同一个数据库同一表格,可能造成数据不同步,显示无效数据。那么给表格上锁,可以使数据有效性。比如A给表格上锁,操作时,B查看不到数据库,需要等待A解锁数据库)

    2)数据库解锁:UNLOCK TABLES tablename;(解锁表格)

    3)数据库回滚:ROLLBACK;

    4)数据关闭/开启自动提交功能:SET AUTOCOMMIT=0/1;

    5)数据库提交:COMMIT;(提交后不能事物回滚)

    6)设置保存点:SAVEPOINT name;(设置保存点为name,回滚跳转保存点为:ROLLBACK TO name)

    7)删除保存点:RELEASE SAVEPOINT;

    我不作恶

    但有权拒绝为善

    我不赞同

    但是我捍卫你不为善的权力

  • 相关阅读:
    NYOJ 625 笨蛋的难题(二)
    NYOJ 102 次方求模
    ZJU Least Common Multiple
    ZJUOJ 1073 Round and Round We Go
    NYOJ 709 异形卵
    HDU 1279 验证角谷猜想
    BNUOJ 1015 信息战(一)——加密程序
    HDU 1202 The calculation of GPA
    "蓝桥杯“基础练习:字母图形
    "蓝桥杯“基础练习:数列特征
  • 原文地址:https://www.cnblogs.com/HackerBlog/p/6071249.html
Copyright © 2011-2022 走看看