`

多_对_多

 
阅读更多
//Hibernate--多对多
--学生表
create table Studentv(
id number primary key,
stuId varchar2(20) not null,
stuName varchar2(50) not null,
stuAge number not null
);
--课程表
create table Coursev(
id number primary key,
couId varchar2(20) not null,
couName varchar2(50) not null
);
--中间表
create table Stu_Couv(
sId number not null,
cId number not null
);

//课程表实体类
public class Coursev implements Serializable
{
    private int id;
    private String cId;
    private String cName;
    private Set<Studentv> stus = new HashSet<Studentv>();
//省略get(),set();
}
//学生实体类
public class Studentv implements Serializable
{
    private int id;
    private String sId;
    private String sName;
    private int sAge;
    private Set<Coursev> cous = new HashSet<Coursev>();
//省略get(),set();
}

//Coursev.hbm.xml
<hibernate-mapping package="com.rt.xbliuc.pojo">
<class name="Coursev" table="Coursev">
<id name="id" column="id">
<generator class="assigned"/>
</id>
<property name="cId" column="couId"/>
<property name="cName" column="couName"/>
<set name="stus" table="Stu_Couv" lazy="true" cascade="all">
<key column="cId"/>
<many-to-many class="com.rt.xbliuc.pojo.Studentv" column="sId"/>
</set>
</class>
</hibernate-mapping>

//Studentv.hbm.xml
<hibernate-mapping package="com.rt.xbliuc.pojo">
<class name="Studentv" table="Studentv">
<id name="id" column="id">
<generator class="assigned"/>
</id>
<property name="sId" column="stuId"/>
<property name="sName" column="stuName"/>
<property name="sAge" column="stuAge"/>
<set name="cous" inverse="true" table="Stu_Couv" lazy="true" cascade="all">
<key column="sId"/>
<many-to-many class="com.rt.xbliuc.pojo.Coursev" column="cId"/>
</set>
</class>
</hibernate-mapping>

//测试类
Transaction transaction = session.beginTransaction();
HashSet<Studentv> cSet = new HashSet<Studentv>();
HashSet<Coursev> sSet = new HashSet<Coursev>();
Studentv s = new Studentv();
Coursev c = new Coursev();
s.setId(1);
s.setsId("s001");
s.setsName("sName");
s.setsAge(20);
c.setId(2);
c.setcId("c001");
c.setcName("cName");
cSet.add(s);
sSet.add(c);
c.setStus(cSet);
s.setCous(sSet);
session.save(s);
transaction.commit();
session.close();
分享到:
评论

相关推荐

    BP_bp多输入_matlab神经网络_多输出预测_多输入多输出_BP多输出_源码.rar

    这样的模型在许多领域都有应用,如气象预报、股票市场分析、工程系统控制等,因为它能够捕捉输入变量间的复杂关系,并对多个响应变量进行联合预测。 MATLAB作为一种强大的数学计算和数据可视化工具,内置了神经网络...

    理解python中__init__.py和__all__

    在一个工程文件下面,我们可能会有很多的py文件(模块),文件太多,管理很不方便,这时候我们就可以创建一个包(package)对这些文件进行管理,把具有共同特征的文件放在同一个package里面,那该如何创建package,很简单...

    mp.rar_socket 多线程_tcp 多线程_tcp 线程_多线程 Socket_网络 扫描器

    标题中的“mp.rar_socket 多线程_tcp 多线程_tcp 线程_多线程 Socket_网络 扫描器”表明这是一个...通过理解和分析这个项目,开发者可以增强对网络编程、多线程以及TCP协议的理解,并掌握如何构建高效的网络扫描工具。

    pi.rar_PI_linux 多线程_多线程_多线程求pi

    然后,线程内部可以使用某种π的近似公式,如格雷戈里-莱布尼茨级数,对各自负责的区间进行迭代计算,最后将所有线程的结果汇总,得到π的估计值。 多线程求π的过程中,还需要考虑线程安全问题。当多个线程同时...

    ssd_mobilenet_v3_large_coco_2020_01_14

    在实际应用中,你可以根据需求对这个预训练模型进行微调,例如添加新的类别或者调整模型的参数。此外,对于资源有限的环境,如手机或嵌入式设备,MobileNetV3的轻量化设计使其成为理想的解决方案。 总结来说,"ssd_...

    BP_bp多输入_matlab神经网络_多输出预测_多输入多输出_BP多输出_源码.zip

    这个压缩包文件“BP_bp多输入_matlab神经网络_多输出预测_多输入多输出_BP多输出_源码.zip”显然包含了用MATLAB语言实现的BP神经网络模型,用于处理多输入和多输出的预测任务。 MATLAB作为一种强大的数值计算和可视...

    TD_Mgd_3.03_9系列_TD_Mgd_td_mgddll_cad_dwg_zuluf9g_

    在压缩包子文件的文件名称列表中,我们可以看到多个DLL文件,这些都是.NET框架下的动态链接库,用于提供特定的功能: 1. TD_Db_3.03_9.dll:可能包含数据库相关功能,用于存储和检索CAD数据。 2. TD_Mgd_3.03_9.dll...

    inception_v3_weights_tf_dim_ordering_tf_kernels.zip

    1. **多尺度信息处理**:通过使用不同大小的卷积核,Inception块可以同时捕获局部和全局信息,增强模型的泛化能力。 2. **降维操作**:为了减少计算量和参数数量,Inception V3引入了“瓶颈”结构,即先进行1x1卷积...

    dlib_face_recognition_resnet_model_v1.dat.zip_ResNet_dlib_face r

    在IT领域,人脸识别是一项重要的技术,它广泛应用于安全监控、社交网络身份验证、智能门禁系统等多个场景。dlib库为开发者提供了一套强大的工具,其中就包括了针对人脸识别的ResNet网络模型——dlib_face_...

    USBDM_Drivers_4_12_1_Win_x64_USBDM_

    "win10x"可能是指Windows 10的多个版本,包括Home、Pro、Enterprise等。 标签"USBDM"直接指明了这个压缩包的核心内容,即与USBDM调试模块相关的软件或驱动程序。 压缩包内的唯一文件"USBDM_Drivers_4_12_1_Win_x64...

    sample_venc_海思venc源码_sample_venc_

    在实际应用中,开发者可能需要根据具体需求对`sample_venc`进行优化,如调整编码参数以平衡画质和带宽,或者实现多路编码、动态码率控制等功能。此外,还可以结合其他模块,如音频编码、流媒体传输等,构建完整的...

    handeye_movingcam_calibration_poses_相机标定_图像矫正_

    这个过程通常通过使用特定的标定板(如棋盘格)来完成,通过对多个不同角度拍摄的标定板图像进行分析,可以计算出这些参数。 在“handeye_movingcam_calibration_poses”中,“handeye”通常指的是机器人与相机之间...

    COCO_val2017_detections_AP_H_56_person.zip

    COCO数据集广泛应用于物体检测、分割、关键点检测等多个视觉任务,提供了大量的图像和详细的注释。"val2017"表示这是验证集,通常用于在模型训练完成后评估模型性能,以确保模型不会过拟合训练数据。 在这个验证...

    Underwater_Image_Enhancement_Using_MultiFusion_Technique-master.zip

    《水底图像增强:多融合技术在Matlab中的应用》 水下图像处理是一门复杂的计算机视觉技术,其主要目标是改善由于水介质对光线传播的影响导致的图像质量下降。"Underwater_Image_Enhancement_Using_MultiFusion_...

    Sim_EKB_Install_2014_11_09_2014_siemensekb_

    不过,对于那些已经习惯旧版操作界面或对新功能需求不大的用户来说,老版本依然具有很高的实用价值。 Sim_EKB_Install_2014_11_09是该软件的安装文件,通常包含了运行和配置EKB所需的所有组件,包括主程序、数据库...

    USB_Burning_Tool_USB_Burning_Tool3_V2_n1_

    描述中的“Amlogic USB Burning Tool_v2.1.6.8.exe”是该USB烧录工具的具体软件版本,这是一个可执行文件(.exe),用户在Windows操作系统上运行此程序来对Amlogic设备进行固件升级。版本号2.1.6.8表明这是该工具的...

    XP_SP2_TCPIP_Patch

    在默认情况下,Windows XP SP2对同时打开的TCP连接数量进行了限制,这在一定程度上影响了多线程应用程序的性能,尤其是那些依赖大量并发连接的网络应用,如P2P下载软件、FTP客户端和某些服务器软件。 TCP/IP...

    en_office_online_server_last_updated_november_2018_x64_dvd

    通过上述内容可以看出,“en_office_online_server_last_updated_november_2018_x64_dvd”涉及了Office Online Server 2018这款产品多个方面的知识要点。希望这些信息能帮助您更好地理解和应用该技术。

    mask_rcnn_inception_v2_coco_2018_01_28(附代码).zip

    C++版本可能需要对这些库进行封装,以便在C++环境中运行。 6. **性能优化**:尽管未使用GPU,但开发者可能已经进行了各种优化,如批量处理、多线程计算、内存管理等,以提高在CPU上的运行效率。 总之,"mask_rcnn_...

Global site tag (gtag.js) - Google Analytics