Hibernate

  •  什么是hibernate

     Hibernate是一个开源的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 

 

  •  数据持久层

数据持久层是用来存取业务状态数据的,数据持久层最基本的功能是将数据持久化到存储到数据库里

 

  •  ORM(对象关系映射)技术内容

    

 

 

  •  ORM映射的三种方式

 

 

 

  •  使用hibernate的基本步骤

    开发步骤:

      

 

 

     使用步骤:

      

 

 

 

  •  hibernate的配置文件

    类名.hbm.xml文件样式   

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">    
<!-- 
    <hibernate-mapping>一般不去配置,采用默认即可。
    schema:指定映射数据库的schema(模式/数据库),如果指定该属性,则表名会自动添加该schema前缀
    package:指定包前缀 指定持久化类所在的包名 这样之后calss子元素中就不必使用全限定性的类名
    default-cascade="none":默认的级联风格,表与表联动。
    default-lazy="true":默认延迟加载
 -->
<hibernate-mapping package="com.lab1">
    <!-- 
        <class>:使用class元素定义一个持久化类。
        name="cn.javass.user.vo.UserModel":持久化类的java全限定名;
        table="tbl_user":对应数据库表名,默认持久化类名作为表名;
        proxy:指定一个接口,在延迟装载时作为代理使用,也可在这里指定该类自己的名字。
        mutable="true":默认为true,设置为false时则不可以被应用程序更新或删除,等价于所有<property>元素的update属性为false,表示整个实例不能被更新。
        dynamic-insert="false":默认为false,动态修改那些有改变过的字段,而不用修改所有字段;
        dynamic-update="false":默认为false,动态插入非空值字段;
        select-before-update="false":默认为false,在修改之前先做一次查询,与用户的值进行对比,有变化都会真正更新;
        optimistic-lock="version":默认为version(检查version/timestamp字段),取值:all(检查全部字段)、dirty(只检查修改过的字段);
                                   none(不使用乐观锁定),此参数主要用来处理并发,每条值都有固定且唯一的版本,版本为最新时才能执行操作;
        如果需要采用继承映射,则class元素下还会增加<subclass.../>元素等用于定义子类。
     -->
    <class name="Tstudent" table="tstudent" >
        
        <!-- 
            <id>:定义了该属性到数据库表主键字段的映射。
            type  指定该标识属性的数据类型,该类型可以是Hibernate的内建类型,也可以是java类型,如果是java类型则需要使用全限定类名(带包名)。该属性可选,如果没有指定类型, 则hibernate自行判断该标识属性数据类型。通常建议设定。
            name="userId":标识属性的名字;
            column="userId":表主键字段的名字,如果不填写与name一样;
            
         -->
         <id name="sid" type="long" column="sid">
			<generator class="assigned" />
		</id>
        <property name="sname" column="sname" />
        <many-to-one name="tunit" column="unit_id" class="Tunit" not-null="true" cascade="all"></many-to-one>
    </class>    
</hibernate-mapping>

  

   hibernate.cfg.xml样式

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration> 
  <session-factory> 
    <!-- 数据库连接:JDBC驱动 -->
    <property 	name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
	<!-- 数据库连接:URL -->
    <property 	name="hibernate.connection.url">jdbc:mysql://localhost/hibernate-database</property>
 	<!-- 数据库连接:用户名 -->
    <property name="hibernate.connection.username">root</property>
   <!-- 数据库连接:密码 -->
    <property name="hibernate.connection.password">123456</property>
	<!-- mysql数据库在hibernate中语言格式 -->
    <property 	name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
    <!-- 自动生成数据库表结构 -->
    <property name="hibernate.hbm2ddl.auto">update</property>
    <!-- 显示Hibernate生成的SQL语句 -->
    <property name="hibernate.show_sql">true</property>
<!-- 映射表xml文件方式 --> <mapping resource="com/lab1/Tunit.hbm.xml"/> <mapping resource="com/lab1/Tstudent.hbm.xml"/>
   <!--映射表注解方式-->  <mapping class="com.lab2.UserInfo"/> </session-factory> </hibernate-configuration>

  

   

  •  hibernate的内置对象标识符生成策略

    

 

 

  •  映射数据类型

     

 

 

  •  表与表的关联映射

     多对一(一对多)

      

 

     一对一:

      

 

     多对多:

      

 

 

  •  持久对象的生命周期

      

 

 

  •  hibernate的事务

    

 

     事务并发问题:

 

 

    锁:

    

 

 

  • 查询

    HQL:(半自动查询)

      

 

       普通:

        

 

 

      分页:

        

 

       设置参数:

        

 

       聚集函数:

        

 

   Criteria查询:(全自动查询)

    

 

 

  • 缓存

   基本流程:

    

 

   开始二级缓存

    

 

     

 

posted @ 2020-06-14 16:44  echso。。  阅读(128)  评论(0编辑  收藏  举报