`
txidol
  • 浏览: 56239 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Hibernate学习笔记(二)【标识符及基本级联配置】

阅读更多

标识符

increment 用于代理主键.由Hibernate自增方式生成标识符,每次增量为1
identity  同上。由底层数据库生成标识符.前提是要数据库支持自增
sequence  同上。由底层数据库生成标识符.前提是要数据库支持序列
hilo      同上。由Hibernate根据high/low算法生成标识符
native    同上。根据数据库的支持,选择identity,sequence或hilo
uuid.hex  同上。由Hibernate采用UUID算法生成字符串形式的标识符
assigned  用于自然主键。由Java代码通过setId()生成标识符。

数据库可使用的标识符

几种常用数据库可以使用的标识符生成器:
1.      MySQL:identity,increment,hilo,native
2.      MS SQL Server:identity,increment,hilo,native
3.      Oracle:sequence,seqhilo,hilo,increment,native
4.      跨平台:native

 

IdentityTester.hbm.xml

 

<hibernate-mapping>
    <class name="mypack.IdentityTester" table="IDENTITY_TESTER">
        <id name="id" type="long" column="ID">
            <generator class="identity"/>        
        </id>
               <property name="name" type="string" column="NAME"/>
    </class>
</hibernate-mapping>

 

IncrementTester.hbm.xml

 

<hibernate-mapping>
    <class name="mypack.IncrementTester" table="INCREMENT_TESTER">       
        <id name="id" type="long" column="ID">
          <meta attribute="scope-set">private</meta>
            <generator class="increment"/>
        </id>
        <property name="name" type="string" column="NAME"/>
    </class>
</hibernate-mapping>

 

NativeTester.hbm.xml

 

<hibernate-mapping>
    <class name="mypack.NativeTester" table="NATIVE_TESTER">
        <id name="id" type="long" column="ID">
            <generator class="native"/>
        </id>
        <property name="name" type="string" column="NAME"/>
    </class>
</hibernate-mapping>

 

HiloTester.hbm.xml 【101 201 301】

 

<hibernate-mapping>
  <class name="mypack.HiloTester"  table="HILO_TESTER">   
    <id name="id" type="long" column="ID">
    <generator class="hilo">
                <param name="table">hi_value</param>
                <param name="column">next_value</param>
                <param name="max_lo">100</param>
        </generator>
    </id>
    <property name="name" type="string" column="NAME" />   
  </class>
</hibernate-mapping>

 

Squence.hbm.xml

 

       <generator class="sequence”>
                <param name="squence”>test_id_seq</param>
        </generator>

 

基础级联 Monkey属于Team

Team.hbm.xml 【inverse="true" cascade="all-delete-orphan"】

 

<hibernate-mapping>
    <class name="mypack.Team" table="TEAMS">       
        <id name="id" type="long" column="ID">      
            <generator class="increment"/>
        </id>
        <property name="name" type="string" column="NAME"/>           
              <set name="monkeys"
                   cascade="all-delete-orphan"
                      inverse="true">
                      <key column="TEAM_ID"/>
                      <one-to-many class="mypack.Monkey"/>
              </set>          
    </class>
</hibernate-mapping>

 

Monkey.hbm.xml 【none delete all delete-orphan all-delete-orphan

 

<hibernate-mapping>
    <class name="mypack.Monkey" table="MONKEYS">
        <id name="id" type="long" column="ID">
            <generator class="increment"/>
        </id>
        <property name="name" type="string" column="NAME"/>       
        <!--mapping with cascade -->      
        <many-to-one
         name="team"
        column="TEAM_ID"
         class="mypack.Team"
         cascade="save-update" <!— none delete all delete-orphan all-delete-orphan  --> 
         lazy="false"  <!-- proxy -->    
        />              
    </class>
</hibernate-mapping>

操作Service类代码片段

 

 

		     tx = session.beginTransaction();
                     Team team = new Team("BULL", new HashSet<Monkey>());
                     Monkey monkey = new Monkey();
                     monkey.setName("Tom");
                     monkey.setTeam(team);
                     team.getMonkeys().add(monkey);
                     session.save(team);
                     tx.commit();
                     tx =session.beginTransaction();
                     Team team =(Team) session.load(Team.class, teamId);
                     Monkey monkey =(Monkey) team.getMonkeys().iterator().next();
                     // 解除team和Monkey的关联关系
                     team.getMonkeys().remove(monkey);
                     monkey.setTeam(null);
                     tx.commit();

 


 

分享到:
评论

相关推荐

    Hibernate学习笔记

    ### Hibernate学习笔记——深入理解ORM框架 #### Hibernate简介与重要性 Hibernate,作为一款流行的开源对象关系映射(ORM)框架,旨在简化Java应用程序与关系型数据库之间的交互过程。传统上,开发人员需要手动...

    hibernate学习笔记

    ### hibernate学习笔记 #### 对象持久化 **概述** 对象持久化是指将程序中的对象状态存储到非易失性存储设备(如硬盘)的过程,以便于后续的应用能够读取这些对象的状态信息。这种方式通常用于解决内存数据的短暂...

    hibernate 学习笔记

    ### Hibernate 学习笔记知识点详解 #### 一、对象持久化的理论 - **定义**: 对象持久化是指将内存中的对象状态保存到外部存储设备(如磁盘)上的过程,以便在需要时能够重新加载并恢复对象的状态。 - **原因**: -...

    hibernate笔记

    **二、Hibernate配置** 1. **Hibernate配置文件(hibernate.cfg.xml)**: 包含数据库连接信息、方言设置、缓存策略等,是初始化Hibernate的必备文件。 2. **实体类映射**: 可以通过XML文件或注解方式定义实体类与...

    win7修复本地系统工具

    win7修复本地系统工具

    《自动化专业英语》04-Automatic-Detection-Block(自动检测模块).ppt

    《自动化专业英语》04-Automatic-Detection-Block(自动检测模块).ppt

    《计算机专业英语》chapter12-Intelligent-Transportation.ppt

    《计算机专业英语》chapter12-Intelligent-Transportation.ppt

    西门子S7-1200博图平台下3轴伺服螺丝机程序解析与应用

    内容概要:本文详细介绍了基于西门子S7-1200博图平台的3轴伺服螺丝机程序。该程序使用SCL语言编写,结合KTP700组态和TIA V14及以上版本,实现了对X、Y、Z三个轴的精密控制。文章首先概述了程序的整体架构,强调了其在自动化控制领域的高参考价值。接着深入探讨了关键代码片段,如轴初始化、运动控制以及主程序的设计思路。此外,还展示了如何通过KTP700组态实现人机交互,并分享了一些实用的操作技巧和技术细节,如状态机设计、HMI交互、异常处理等。 适用人群:从事自动化控制系统开发的技术人员,尤其是对西门子PLC编程感兴趣的工程师。 使用场景及目标:适用于希望深入了解西门子S7-1200博图平台及其SCL语言编程特点的学习者;旨在帮助读者掌握3轴伺服系统的具体实现方法,提高实际项目中的编程能力。 其他说明:文中提供的代码示例和设计理念不仅有助于理解和学习,还能直接应用于类似的实际工程项目中。

    MATLAB仿真:非线性滤波器在水下长基线定位(LBL)系统的应用与比较

    内容概要:本文详细探讨了五种非线性滤波器(卡尔曼滤波(KF)、扩展卡尔曼滤波(EKF)、无迹卡尔曼滤波(UKF)、粒子滤波(PF)和变维卡尔曼滤波(VDKF))在水下长基线定位(LBL)系统中的应用。通过对每种滤波器的具体实现进行MATLAB代码展示,分析了它们在不同条件下的优缺点。例如,KF适用于线性系统但在非线性环境中失效;EKF通过雅可比矩阵线性化处理非线性问题,但在剧烈机动时表现不佳;UKF利用sigma点处理非线性,精度较高但计算量大;PF采用蒙特卡罗方法,鲁棒性强但计算耗时;VDKF能够动态调整状态维度,适合信标数量变化的场景。 适合人群:从事水下机器人(AUV)导航研究的技术人员、研究生以及对非线性滤波感兴趣的科研工作者。 使用场景及目标:①理解各种非线性滤波器的工作原理及其在水下定位中的具体应用;②评估不同滤波器在特定条件下的性能,以便为实际项目选择合适的滤波器;③掌握MATLAB实现非线性滤波器的方法和技术。 其他说明:文中提供了详细的MATLAB代码片段,帮助读者更好地理解和实现这些滤波器。此外,还讨论了数值稳定性问题和一些实用技巧,如Cholesky分解失败的处理方法。

    VMware-workstation-full-14.1.3-9474260

    VMware-workstation-full-14.1.3-9474260

    DeepSeek系列-提示词工程和落地场景.pdf

    DeepSeek系列-提示词工程和落地场景.pdf

    javaSE阶段面试题

    javaSE阶段面试题

    《综合布线施工技术》第5章-综合布线工程测试.ppt

    《综合布线施工技术》第5章-综合布线工程测试.ppt

    安川机器人NX100使用说明书.pdf

    安川机器人NX100使用说明书.pdf

    S7-1200 PLC改造M7120平面磨床电气控制系统:IO分配、梯形图设计及组态画面实现

    内容概要:本文详细介绍了将M7120型平面磨床的传统继电器控制系统升级为基于西门子S7-1200 PLC的自动化控制系统的过程。主要内容涵盖IO分配、梯形图设计和组态画面实现。通过合理的IO分配,确保了系统的可靠性和可维护性;梯形图设计实现了主控制逻辑、砂轮升降控制和报警逻辑等功能;组态画面则提供了友好的人机交互界面,便于操作和监控。此次改造显著提高了设备的自动化水平、运行效率和可靠性,降低了维护成本。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是熟悉PLC编程和控制系统设计的专业人士。 使用场景及目标:适用于需要进行老旧设备升级改造的企业,旨在提高生产设备的自动化水平和可靠性,降低故障率和维护成本。具体应用场景包括但不限于金属加工行业中的平面磨床等设备的控制系统改造。 其他说明:文中还分享了一些实际调试中的经验和技巧,如急停逻辑的设计、信号抖动的处理方法等,有助于读者在类似项目中借鉴和应用。

    chromedriver-linux64-136.0.7103.48.zip

    chromedriver-linux64-136.0.7103.48.zip

    IMG_20250421_180507.jpg

    IMG_20250421_180507.jpg

    《网络营销策划实务》项目一-网络营销策划认知.ppt

    《网络营销策划实务》项目一-网络营销策划认知.ppt

    Lianantech_Security-Vulnerabil_1744433229.zip

    Lianantech_Security-Vulnerabil_1744433229

    MybatisCodeHelperNew2019.1-2023.1-3.4.1.zip

    MybatisCodeHelperNew2019.1-2023.1-3.4.1

Global site tag (gtag.js) - Google Analytics