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.构造器注入

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • java基本输入语句_java键盘输入语句

    java基本输入语句_java键盘输入语句在Java中进行输入时,最常用的两种输入方式为:1.使用ScannerScanner使用步骤:导入包importjava.util.Scanner;//导包的动作必须出现在类定义的上方创建对象//newScanner(System.in)为固定格式,不可以改变Scannersc=newScanner(System.in); 接收数据inti=sc.nextInt(); //这里使用的为int型,如果改变,则需要改变sc.nextInt();

  • 网关,路由器,局域网,广域网络_局域网和广域网是什么意思

    网关,路由器,局域网,广域网络_局域网和广域网是什么意思网关、路由器、局域网、广域网网关:连接一个网络到另一个网络的关口,不同的网络有不同的网络地址,以及不同的网络中的主机分配有不同的段的ip地址。网关可以实现广域网的互连,也可以实现局域网的互连现在通常说的网关就是路由器的IP只要两台电脑能够相互ping的通,就说明两台电脑属于在同一个局域网中。路由器局域网就是内网,而内网就是局域网,一个学校,一个单位就是一个局域网,在同一个局域网中,所有的ip都是不一样的,但是在两个不同的局域网中,ip地址可以一样,使用ipconfig

  • 注册网页_dubbo服务注册

    注册网页_dubbo服务注册大概在去年的时候发现生产环境使用eureka经常会发现服务假死eureka没有给踢掉的情况,然后就衍生了要不就换个注册中心试试,然后就了解到了nacos,正好他还融合了配置中心,但是后来碍于切换时怕生产环境不稳定,丢数据等问题就一直没有换,但后续的项目的注册中心都换成了nacos,这篇文章我就来模拟一下如何将eureka平滑切换成nacos………………

  • navicat15 永久激活码最新_最新在线免费激活

    (navicat15 永久激活码最新)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html1STL5S9V8F-eyJsaWNlbnNlSW…

  • Ubuntu修改密码和用户名

    Ubuntu修改密码和用户名​Ubuntu是一个Linux操作系统,修改密码和用户名是有危险的动作,请谨慎修改。一、Ubuntu修改密码和用户名Ubuntu更改密码步骤:1、进入Ubuntu,打开一个终端,输入sudosu转为root用户。注意,必须先转为root用户!!!2、sudopasswduser(user是对应的用户名)3、输入新密码,确认密码。4、修改密码成功,重启,输入新密码进入Ubun…

  • 三维点云拼接的方法_图像拼接算法研究

    三维点云拼接的方法_图像拼接算法研究apap算法:mdltmatlab很多内置函数都是对列操作,如mean()VLFEAT库检测和匹配SIFT关键点kp1,kp2,matches关键点坐标齐次化:(x,y,1)归一化:normalise2dpts,Functiontranslatesandnormalisesasetof2Dhomogeneouspointssothatthei…

发表回复

您的电子邮箱地址不会被公开。

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