`

基于Annotation 的多对一ManyToOne双向和基于XML配置多对一双向

阅读更多
基于Annotation:
package com.stark.hibernate.model;

import java.util.HashSet;
import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToMany;
import javax.persistence.Table;

@Entity
@Table(name="t_group")
public class Group {
private int groupId ;
private String groupName;
private Set<User> users= new HashSet<User>();
@Id
@GeneratedValue
public int getGroupId() {
return groupId;
}
public void setGroupId(int id) {
this.groupId = id;
}
public String getGroupName() {
return groupName;
}
public void setGroupName(String name) {
this.groupName = name;
}
/**
* One 代表Group,Many代表User ,我们需要在多的一方添加外键,如果不添加@JoinColumn(name="groupId"),将会生成一张t_group_t_user的中间表
* 否则将会在user表中自动添加groupId字段
* @return
*/
@OneToMany(mappedBy="group",cascade = { CascadeType.ALL})
@JoinColumn(name="groupId")
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}


}

PS:需要在Group表中添加OneToMany(mappedBy="group"),目的就是外键由User表来指定,如果不添加,将会在User中自动添加一条t_group_id,这是冗余字段的


package com.stark.hibernate.model;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

@Entity
@Table(name="t_user")
public class User {
private int userId;
private String userName;
private Group group;
@Id
@GeneratedValue
public int getUserId() {
return userId;
}

public void setUserId(int userId) {
this.userId = userId;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}


/**
*
* 只需在多方User中添加一个Group同时添加注解@ManyToOne即可(Many代表User,One代表Group)
*/
@ManyToOne
@JoinColumn(name="groupId")
public Group getGroup() {
return group;
}
public void setGroup(Group group) {
this.group = group;
}



}
生成DDL语句为:
create table t_group (groupId integer not null auto_increment, groupName varchar(255), primary key (groupId))
create table t_user (userId integer not null auto_increment, userName varchar(255), groupId integer, primary key (userId))
alter table t_user add index FKCB63CCB65F00FCD6 (groupId), add constraint FKCB63CCB65F00FCD6 foreign key (groupId) references t_group (groupId)

基于XML:
去掉Group和UserJavaBean中所有@注解
Group.hbm.xml:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.stark.hibernate.model">
    <class name="Group" table="t_group">
        <id name="groupId" >
            <generator class="native"/>
        </id>
        <property name="groupName"/>
        <set name="users">
         <key column="groupId"></key>
        <one-to-many class="User"/>
        </set>
    </class>
</hibernate-mapping>

User.hml.xml:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.stark.hibernate.model">
    <class name="User" table="t_user">
        <id name="userId">
            <generator class="native"/>
        </id>
        <property name="userName" />
        <many-to-one name="group" column="groupId" cascade="all" ></many-to-one>
 
    </class>
</hibernate-mapping>

生成DDL语句:
与用Annotation生成的是一样的。






分享到:
评论

相关推荐

    vc++全版本组件大全.zip

    vc++全版本组件大全 VC++运行时(Visual C++ Runtime)是VC++开发环境中用于支持C和C++程序运行的基础库集合。这些库包含了执行C/C++程序所必需的基本函数和数据结构,例如内存管理、字符串操作、输入输出处理、异常处理等。VC++运行时库分为静态库和动态库两种形式,以适应不同类型的项目需求。 静态链接库 vs 动态链接库 静态链接库(Static Linking Libraries):在编译时,静态库的代码会被直接嵌入到最终生成的可执行文件中。这意味着每个使用静态库的程序都会包含库代码的一个副本,导致最终程序的体积较大,但不需要外部库文件支持即可独立运行。在VC++中,静态链接库的例子有LIBC.lib(用于单线程程序)和LIBCMT.lib(用于多线程程序)。 动态链接库(Dynamic Link Libraries):与静态链接相反,动态库的代码并不直接加入到应用程序中,而是在程序运行时被加载。这使得多个程序可以共享同一份库代码,节省了系统资源。VC++的动态运行时库主要通过msvcrt.dll(或其变体,如MSVCRTD.dll用于调试版本)实现,与之配套的导入库(Import Library)如CRTDLL.lib用于链接阶段。 运行时库的版本 VC++运行时库随着Visual Studio版本的更新而发展,每个版本都可能引入新的特性和优化,同时保持向后兼容性。例如,有VC++ 2005、2008、2010直至2019等多个版本的运行时库,每个版本都对应着特定的开发环境和Windows操作系统。 重要性 VC++运行时对于确保程序正确运行至关重要。当程序在没有安装相应运行时库的计算机上执行时,可能会遇到因缺失DLL文件(如MSVCP*.dll, VCRUNTIME*.dll等)而导致的错误。因此,开发完成后,通常需要分发相应的VC++ Redistributable Packages给最终用户安装,以确保程序能够在目标系统上顺利运行。 安装与部署 安装VC++运行时库通常是通过Microsoft提供的Redistributable Packages完成的,这是一个简单的过程,用户只需运行安装程序即可自动安装所需组件。对于开发者而言,了解和管理不同版本的运行时库对于确保应用程序的广泛兼容性和可靠性是必要的。

    Johnson -- Make Your Own Python Text Adventure -- 2018.pdf

    Johnson -- Make Your Own Python Text Adventure -- 2018

    cbqri risc-v

    cbqri risc-v

    山东建筑大学PLC部分课后习题答案.doc

    plc

    2021-2027中东人工智能市场现状及未来发展趋势.docx

    2021-2027中东人工智能市场现状及未来发展趋势.docx

    如何画梯形图- plc梯形图怎么画-如何画plc梯形图.doc

    如何画梯形图- plc梯形图怎么画-如何画plc梯形图.doc

    深度报告2024-国金证券-计算机行业研究_如何实现AGI_大模型现状及发展路径展望.pdf

    本报告《深度报告2024-国金证券-计算机行业研究_如何实现AGI_大模型现状及发展路径展望》全面剖析了人工智能领域中的关键议题——通用人工智能(AGI)的实现路径,深入探讨了当前大模型技术的最新进展、技术挑战、市场应用前景以及未来发展趋势。报告不仅详细分析了国内外知名大模型的技术特点与优势,还从政策环境、技术突破、产业链布局等多个维度,为投资者、行业研究者及科技企业提供了宝贵的洞察与策略建议。

    GmaGIS V0.0.0a4 版本安装包

    基于Python开发的 GIS软件。基于PyQT5 和 gma 包,打造的GIS软件GmaGIS。当前为第四个预览版 V0.0.0a4,完全开源免费,源代码可看。欢迎下载和传播。

    制造模式转型下资产管理数字化解决方案两份资料.pptx

    制造模式转型下资产管理数字化解决方案两份资料.pptx

    android studio开发app项目.docx

    开发 Android 应用程序通常使用 Android Studio,这是官方推荐的集成开发环境(IDE)。下面是开发 Android 应用程序的基本步骤和一些关键点: 步骤概述: 安装 Android Studio: 下载并安装最新版本的 Android Studio。它包含了所有开发 Android 应用所需的工具和库。 创建新项目: 打开 Android Studio,选择 "Start a new Android Studio project" 创建一个新项目。 配置项目名称、包名、保存位置等。 选择项目模板: Android Studio 提供了各种模板,如空白活动、基础活动、导航活动等。选择适合你应用结构的模板。 设计用户界面: 使用 Android Studio 提供的布局编辑器(Layout Editor)设计应用的用户界面。 可以通过拖放方式添加控件,并在 XML 中编辑布局。 编写代码: 在 Java 或 Kotlin 中编写应用逻辑和功能。 Android Studio 提供了丰富的模板和代码片段,帮助加速开发。

    计算机编程:C语言文件I/O操作基础与实践指南

    C语言提供了多种文件读写操作的函数,这些函数定义在`<stdio.h>`头文件中。以下是一些基本的文件读写操作示例代码: ### 文件打开与关闭 在进行文件读写之前,需要使用`fopen`函数打开文件,并在操作完成后使用`fclose`函数关闭文件。 ```c #include <stdio.h> int main() { FILE *file; file = fopen("example.txt", "r"); // 以只读模式打开文件 if (file == NULL) { perror("Error opening file"); return -1; } // 进行文件读写操作... fclose(file); // 关闭文件 return 0; } ``` ### 读取文件 使用`fscanf`、`fgets`或`fread`函数可以从文件中读取数据。 ```c char buffer[100]; // 使用fgets从文件中读取一行 fgets(buffer, siz

    制造企业智慧物流架构解决方案两份文件.pptx

    制造企业智慧物流架构解决方案两份文件.pptx

    -立体仓库模拟装置的设计及控制(PLC控制类)控制部分设计.docx

    plc

    抢答器PLC控制系统设计.doc

    抢答器PLC控制系统设计.doc

    305建筑结构水电欧式6套(14.5x20.2)\施工图\D型施工图\燃施-5.dwg

    305建筑结构水电欧式6套(14.5x20.2)\施工图\D型施工图\燃施-5.dwg

    基于改进粒子群优化算法的支持向量机分类识别方法(IPSO- SVM)

    基于改进粒子群优化算法的支持向量机分类识别方法(IPSO-SVM) 1、基于改进粒子群优化算法的支持向量机分类模型 优化方法:①非线性权重递减;②自适应学习因子 运行方式:matlab代码,要求Matlab 2018B及以上版本,只需两个运行.m文件即可 数据导入:①导入数据集之前,删掉文件名后括号里的内容,否则无法运行! ②如需打乱数据集,删除代码res = res(randperm(num_res), :)前的符号 ③附赠4分类及9分类数据集,如需替换自己数据,直接删除原始“数据集.xlsx”内数据,将自己数据复制到改文件中,最后一列要求第一个数据为1! 2、PSO及其IPSO算法寻优收敛曲线 Matlab代码,点击main_compare即可运行,输出PSO与IPSO算法寻优结果对比图

Global site tag (gtag.js) - Google Analytics