Hibernate知识点总结

Hibernate知识点总结

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

Hibernate配置二级缓存:  — 使用EhCache

1.hibernate.cfg.xml中配置二级缓存

<hibernate-configuration>

  <session-factory>

<!– 使用EHCache配置Hibernate二级缓存 –>

    <property name=”hibernate.cache.user_second_level_cache”>true</property>

    <property name=”hibernate.cache.provider_class”>org.hibernate.cache.EhCacheProvider</property>

  </session-factory>

</hibernate-configuration>  

2.在持久化类的映射文件里须要指定缓存的同步策略,关键代码:

   — 产品信息字段配置信息

<hibernate-mapping>

<class name=”com.mr.product.Product” table=”tab+product”>

<cache usage=”read-only”>                           //指定缓存的同步策略

</hibernate-mapping>

3.在项目的classpath根文件夹下添�换成配置文件ehcache.xml,该文件可一直hibernate的zip包下的etc文件夹中找到。

  缓存配置文件代码例如以下:

<ehcache>

<defaultCache

        maxElementsInMemory=”10000″

        eternal=”false”

        timeToIdleSeconds=”120″

        timeToLiveSeconds=”120″

        overflowToDisk=”true”

        />

</ehcache>

  Hibernate的映射关系

双向多对一关联:product  n <—> 1  factory

既能够通过主控方载入被控方,也能够通过被控方载入主控方

factory配置:

       //定义一对多映射

        <set name=”products” 

          inverse=”true”>

          <key column=”factoryid”/>

          <one-to-many class=”com.mr.product.Product”/>

        </set>

product配置:

      //定义多对一映射

        <many-to-one name=”factory” class=”com.mr.factory.Factory”>

        <column name=”factoryid”>

        </many-to-one>

一对一外键关联  — 实际上就是多对一关联的一个特例而已,须要保证关联字段的唯一性,

                                        在<many-to-one>元素中通过 unique属性就可实现关联字段的唯一性

配置一对一关联: People <—> IDcard

               

People映射配置:一对一映射

            <many-to-one name=”idcard” unique=”true”>

               <column name=”card_id”/>

            </many-to-one>

多对多关联: — 通过中间表             user          user-role            role

                        

                                                                id                 id                         id

                                                                name         user_id               rolename

                                                                                   role_id

User映射:

       <set name=”roles” table=”table_user_role”>

                 <key column=”user_id”></key>

                 <many-to-many class=”com.mr.role.Role” column=”role_id”/>

       </set>

       

Role映射:

       <set name=”users” table=”table_user_role”>

                 <key column=”role_id”></key>

                 <many-to-many class=”com.mr.user.User” column=”user_id”/>

       </set>

级联操作:  —  当主控方运行save、update、delete操作时,管理对象(被控方)是否进行同步操作,

                 在映射文件里通过对 cascade属性的设置决定是否对关联对象採用级联操作。

      

      cascade级联操作參数设置:

      

      all                         全部情况均採用级联操作

      none                        默认參数,全部情况下均不採用级联操作

      save-update                 在运行save-update方法时运行级联操作

      delete                      在运行delete方法时运行级联操作

    

    eg:对于People   —   设置级联删除,当删除People对象的时候,会级联删除关联的IDcard对象,即delete People时,会先有一条select的SQL,再有两条delet的SQL

       <one-to-one name=”idcard” calss=”com.mr.idcard.IDcard” cascade=”delete”></one-to-one>  

HQL查询:

      语法:

      select     对象.属性名

      from       对象

      where      过滤条件

      group by   对象.属性名 

      having     分组条件

      order by   对象.属性名

实体对象查询

   from 对象 对象别名 where 条件

   eg:

   Query q = session.createQuery(“from Employee emp”);

   emplist = q.list();

HQL參数绑定机制: 

   

   1.绑定?占位符

   eg:

   Query q = session.createQuery(“from Employee emp where sex =?”);

   q.setParameter(0,”男”);

   emplist = q.list();

   1.绑定:parameter占位符

   eg:

   Query q = session.createQuery(“from Employee emp where sex =:sex”);

   q.setParameter(“sex”,”男”);

   emplist = q.list();

Spring :

 

 1.使用BeanFactory管理bean ,在getBean方法之前,不会实例化对象

   eg:装载bean:

     Resource resource = new ClassPathResource(“applicationContext.xml”);  //装载配置文件

     BeanFactory factory = new XmlBeanFactory(resource);

     Test test = (Test)factory.getBean(“test”);

     

 2.ApplicationContext的应用:

   ApplicationContext扩展了BeanFactory的功能,加入�了如I18n,生命周期时间的公布监听等更强大的功能

   

   ApplicationContext接口有3个实现类,能够实例化当中不论什么一个类来创建Spring的ApplicationContext容器。

      

      1.ClassPathXmlApplicationContext  — 从当前类路径中检索配置文件并装载它来创建容器的实例:

        eg:  ApplicationContext context = new ClassPathXmlApplicationContext(String configLocation);

        

      2.FileSystemXmlApplicationContext — 通过參数指定配置文件的位置,能够获取类路径之外的资源。

        eg: ApplicationContext context = FileSystemXmlApplicationContext(String configLocation);

     

      3.WebApplicationContext           — Spring的Web应用容器,有两种方法能够在Servlet中使用WebApplicationContext

         1.在Servlet的web.xml中配置Sping的ContextLoaderListener监听器

         2.web.xml中,加入�一个Servlet,使用Spring的org.springframework.web.context.ContextLoaderServlet类

         

 依赖注入的三种类型:

    1.接口注入

    2.setter注入

    3.构造器注入

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118882.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月29日 下午8:00
下一篇 2021年11月29日 下午8:00


相关推荐

  • elasticsearch导出大量数据_error attempting to get column

    elasticsearch导出大量数据_error attempting to get column今天在自己本地测试启动ElasticSearch和Kibana时,ElasticSearch已经启动的情况下,去启动Kibana时,报:UnabletoretrieveversioninformationfromElasticsearchnodes.网上找了下资料,说是elasticsearch.yml文件配置问题,但好像并没有说具体是哪里除了问题的。然后自己看了下,因为都是在本地,可能是因为公司网络的原因,不能用localhost,所以,我就把elasticsearch.yml和kiba

    2025年11月10日
    4
  • EPEL 是什么

    EPEL 是什么EPEL 源 是什么全称 nbsp EPEL 源 nbsp nbsp 来源 https www cnblogs com fps2tao p 7580188 html nbsp nbsp nbsp nbsp nbsp EPEL nbsp ExtraPackage 是基于 Fedora 的一个项目 为 红帽系 的操作系统提供额外的软件包 适用于 RHEL CentOS 和 ScientificLi 使用很简单 1 首先我们需要安装一

    2026年3月18日
    3
  • 开发报错记录解决(一):AttributeError: module ‘pywt‘ has no attribute ‘wavedec2‘

    开发报错记录解决(一):AttributeError: module ‘pywt‘ has no attribute ‘wavedec2‘当遇到类似module‘pywt’hasnoattribute‘wavedec’之类的错误的时候.例如:AttributeError:module’pywt’hasnoattribute’wavedec2’按下面的步骤走一遍就可以:步骤:1、打开cmd终端或Anaconda3终端。2、输入pipuninstallpywt。3、输入pipinstallPyWavelets。问题解决。…

    2022年7月23日
    19
  • noip2012借教室_noip小学组

    noip2012借教室_noip小学组这个题首先很容易想到枚举1-m,再一个一个加起来,判断一下(最直白的暴力)于是又很容易想到用差分数组可以优化一下。就像这样#include<iostream>#include<cstdio>usingnamespacestd;constintmaxn=1000005;intd[maxn],s[maxn],t[maxn],r[maxn];…

    2022年8月22日
    7
  • 证明一元函数有界性的方法

    证明一元函数有界性的方法大学生数学竞赛 非数学 证明一元函数有界性常用方法什么是有界函数 有界函数是设 f x 是区间 E 上的函数 若对于任意的 x 属于 E 存在常数 m M 使得 m f x M 则称 f x 是区间 E 上的有界函数 其中 m 称为 f x 在区间 E 上的下界 M 称为 f x 在区间 E 上的上界 有界函数并不一定是连续的 根据定义 在 D 上有上 下 界 则意味着值域 D 是一个有上 下 界的数集 根据确界原理 在定义域

    2026年3月17日
    1
  • python闭包详解_python闭包的使用场景

    python闭包详解_python闭包的使用场景闭包首先了解一下:如果在一个函数的内部定义了另一个函数,外部的我们叫他外函数,内部的我们叫他内函数。在一个外函数中定义了一个内函数,内函数里运用了外函数的临时变量,并且外函数的返回值是内函数的引用

    2022年7月29日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号