• 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;

    我不作恶

    但有权拒绝为善

    我不赞同

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

  • 相关阅读:
    Java-IO流系列-随机存取文件流
    Java-IO流系列-标准输入输出流
    Java-IO流系列-转换流
    Java-IO流系列-缓冲流
    Java-IO流系列-FileInputStream和FileOutStream
    Java-IO流系列-FileReader与FileWriter
    Java-IO流系列-IO流原理以及流的分类
    windows使用chrome调试ios webView
    页面上多个audio只播放一个
    阿里网盘分享
  • 原文地址:https://www.cnblogs.com/HackerBlog/p/6071249.html
Copyright © 2020-2023  润新知