hibernate

作者: 呦後 | 来源:发表于2017-07-28 17:11 被阅读0次

    Hibernate概述(5.0.7版本)

    • 是一个标准的ORM框架
      • 操作对象就相当于操作表结构通过映射文件把对象和表关联起来
    • 对JDBC的一个封装

    优点:
    1、 简化了jdbc的繁琐编码
    2、对面向对象特性的良好支持

    缺点:
    1、不支持动态sql,灵活性较低
    2、 不适合大规模的数据处理

    开发环境的搭建

    1、导入jar包

    Hibernate压缩包下lib包下的required包下所有的jar包+log4j+mysql驱动包

    2、配置映射文件
    写在实体类同包下 推荐命名规则 类名.hbm.xml

    <?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">
        
    <hibernate-mapping>
        <!-- name实体类全路径   table表名-->
    <class name="com.hemi.bean.User"  table="user">
        <!-- name实体类属性名 column表中字段名  -->
        <id name="id"  column="id">
            <!-- 规定主键生成策略 -->
            <generator class="native"></generator>
        </id>
        <property name="name" column="name"></property>
        <property name="age" column="age"></property>
    </class>
    </hibernate-mapping>
    

    主键生成策略:最常用两种
    native(根据本地数据库支持主键生成方式)
    uuid(根据uuid算法生成一个32位16进制的字符串)

    3、配置文件
    写在src根目录下 推荐命名规则hibernate.cfg.xml

    <?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>
            <!-- 配置连接数据库4大参数 -->
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql:///test</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">123456</property>
        
        <!-- 配置方言 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        
        <!-- 选配 -->
        <!-- 打印sql语句 -->
        <property name="show_sql">true</property>
        <!-- 格式化sql语句 -->
        <property name="format_sql">true</property>
        <!-- 映射生成user表 -->
        <property name="hbm2ddl.auto">update</property>
        <!-- 加载映射配置文件 -->
        <mapping resource="com/hemi/bean/User.hbm.xml"/>
        </session-factory>
    
        </hibernate-configuration>
    

    4、使用Hibernate APi操作

    a、得到工厂对象

            //创建Configuration对象
            Configuration configuration = new Configuration();
            //加载配置文件  默认加载名为 hibernate.cfg.xml的文件
            Configuration configure = configuration.configure();
            //创建SessionFactory
            SessionFactory factory = configure.buildSessionFactory();
            System.out.println(factory);
    

    b、打开session

            Session session = factory.openSession();
    

    c、开启事务

            Transaction transaction = session.beginTransaction();
    

    d、crud操作

            //创建对象并设置值
            User user=new User();
            user.setAge(20);
            user.setName("marry1");
            //通过save方法添加数据到数据库
            session.save(user);
    

    e、提交事务

        transaction.commit();
    

    f、关闭session

    session.close();
    

    session方法

    增和改

    save(object);//增
    save执行过后对象为持久态
    saveOrUpdate(object);
    1、插入或修改
    2、当没设置存入数据的主键执行save
    3、设置了 执行update
    4、当主键不存在报错

    merge(object);
    1、插入或修改 先查询
    2、当没设置存入数据的主键执行save
    3、设置了 先去查询 如果主键存在 则修改 不存在则插入
    4、瞬时态的数据被merge操作后变成游离态,返回的数据为持久态
    update(object);//改 建议先查询后修改

    查询

    get(实体类.class,主键);
    一执行马上发生sql语句查询

    load(实体类.class,主键);
    延迟查询 执行后不马上去查询 当有用到查询结果时才发生sql语句去查询

    delete(object); //建议先查再删

    对象三大状态

    1、瞬时态: 刚创建
    2、持久态: 被保存到数据库中且被持久化(session缓存中) [既数据库中有session缓存中也有]
    3、游离态: 被持久化过后 数据库中有之对应的记录但是脱离了session

    1.jpg

    快照机制

    从数据库查询出的数据会在缓存和快照区各有一个 当调用clear或者close方法刷新缓存时,来和快照区数据比对,有更新就推入数据库

    相关文章

      网友评论

          本文标题:hibernate

          本文链接:https://www.haomeiwen.com/subject/wquecxtx.html