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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • freemarker生成java代码_freemarker生成word文档

    freemarker生成java代码_freemarker生成word文档java用freemarker生成word文档.    步骤如下:1,新建一个word文档,另存为test.xml格式的.2,新建java类.(使用freemarker-2.3.10.jar包.请自行下载.)3,把里面需要替换的换成${name}这种. 对应语法参考freemarkerapi.包结构如下:java类:packa

    2022年10月10日
    0
  • 时滞微分方程求解_泛函微分方程内容设计

    时滞微分方程求解_泛函微分方程内容设计时滞微分方程(DDE)是当前时间的解与过去时间的解相关的常微分方程。该时滞可以固定不变、与时间相关、与状态相关或与导数相关。要开始积分,通常必须提供历史解,以便求解器可以获取初始积分点之前的时间的解。常时滞DDE具有常时滞的微分方程组的形式如下:y′(t)=f(t,y(t),y(t−τ1),…,y(t−τk)).y'(t)=f(t,y(t),y(t−τ_1),…,y(t−τ_k)).y′(t)=f(t,y(t),y(t−τ1​),…,y(t−τk​)).此处,t为自变量,y为因变量的列向量,

    2022年10月1日
    0
  • mysql统计表字段数量「建议收藏」

    mysql统计表字段数量「建议收藏」mysql统计表字段数量

    2022年4月23日
    46
  • 复杂json转MAP对象

    复杂json转MAP对象普通json对象或者字符串转换map或者实体就不说了,这里主要提供复杂json转map的方法,直接上java代码了:publicclassJsonUtils{ /** *类描述:复杂json字符串转换为Map,包含数组时value为List。 */ publicstaticMapjson2Map(Stringjson){ LinkedMap

    2022年6月16日
    23
  • scrollIntoView 实现「建议收藏」

    scrollIntoView 实现「建议收藏」1.应用场景: 相信大家都曾经遇到过要将屏幕的某一部分滚到到用户视窗里,例如聊天信息的自动滚屏等,这个有不少解决方案: 1.聊天面板的scrolltop=scrollheight2.消息最后加一个element,然后element.scrollIntoView但是如果想要任一容器中间的一个元素,滚到该容器的视窗显示部分…

    2022年6月28日
    27
  • C/C++:long int与long long的区别

    C/C++:long int与long long的区别longint  longint即long,给人的感觉好像是长整型,但实际上,它和int一样,只有32位。cppreference给出的定义是——int-basicintegertype.Thekeywordintmaybeomittedifanyofthemodifierslistedbelowareused.Ifnolengthmodif…

    2022年6月6日
    53

发表回复

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

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