24.11.26 Mybatis2

resultMap 中的标签和属性

如果是主键列 一般用id标签对应   propertyjava对象的属性  column 数据库中的列( javaType实体类数据类型 jdbcType数据库列的数据类型 ) 不需要配置 <id property="empno" column="empno"  />如果是普通列 一般用result对应  propertyjava对象的属性  column 数据库中的列
<result property="ename" column="ename" />

高级映射 (映射数据与对象的对应关系) 如果列不指定 不能自动对应

通常搭配继承一起使用 体现基础字段的对应

association 对应某个实体对象

Emp对象中 有部门信息 在java中 包含一个Dept对象

package com.javasm.entity;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import java.util.Date;
import java.io.Serializable;/*** (Emp)实体类** @author makejava* @since 2024-11-26 09:40:43*/@Data
@NoArgsConstructor
@AllArgsConstructor
public class Emp implements Serializable {private static final long serialVersionUID = -16018027389934188L;private Integer empno;private String ename;private String job;private Integer mgr;private String hiredate;private Double sal;private Double comm;//关联部门信息private Dept dept;//    private Integer deptno;
//
//
//    private String dname;
//
//    private String loc;}

映射文件配置

<resultMap id="EmpMapBasMap" type="com.javasm.entity.Emp" >
<!--   主键列用id    -->
<!--        实体类属性名       数据库列      ( javaType实体类数据类型  jdbcType数据库列的数据类型 ) 不需要配置           --><id property="empno" column="empno"  />
<!--   其他列用result    --><result property="ename" column="ename" /><result property="job" column="job" /><result property="mgr" column="mgr" /><result property="hiredate" column="hiredate" /><result property="sal" column="sal" /><result property="comm" column="comm" /></resultMap><resultMap id="EmpMapWithDept" extends="EmpMapBasMap" type="com.javasm.entity.Emp" ><!--            实体类属性名     数据库列     --><!--   高级映射(对象映射标签)  需要手动指定所有字段association  解析resultSet数据时 可以创建多个对象collection配置关联的对象     --><association property="dept" javaType="com.javasm.entity.Dept"><id property="deptno" column="deptno"  /><result property="dname" column="dname" /><result property="loc" column="loc" /></association></resultMap>

通过sql语句 把需要的数据查询出来

select * from emp e,dept d where e.deptno = d.deptno

collection 对应集合

每个Dept中都有多个Emp List<Emp>

每个部门有多个员工 部门对象中 包含Emp的集合

package com.javasm.entity;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;import java.util.List;@Data
@NoArgsConstructor
@AllArgsConstructor
public class Dept {private Integer deptno;private String dname;private String loc;//多方的数据集合private List<Emp> emps;}

映射配置

<!-- 基础字段映射 --><resultMap id="DeptBasMap" type="com.javasm.entity.Dept" ><id property="deptno" column="deptno"  /><result property="dname" column="dname" /><result property="loc" column="loc" /></resultMap><resultMap id="DeptWithEmps" extends="DeptBasMap" type="com.javasm.entity.Dept">
<!--    聚合 对应集合对象    --><collection property="emps" ofType="com.javasm.entity.Emp"><id property="empno" column="empno"  /><result property="ename" column="ename" /><result property="job" column="job" /><result property="mgr" column="mgr" /><result property="hiredate" column="hiredate" /><result property="sal" column="sal" /><result property="comm" column="comm" /></collection></resultMap>

sql语句

select * from dept d left join emp e on  d.deptno  = e.deptno
order by d.deptno

2数据库关联查询

表有数据关联时 需要做关联查询

-- 连表查询

-- 简化语法 使用内连接 
select * from emp e,dept d where e.deptno = d.deptno 
-- 标准sql语法 内连接
select * from emp e INNER JOIN dept d on e.deptno = d.deptno
-- 外连接 left right 哪一方显示全集
select d.*,e.* from emp e right join dept d on e.deptno = d.deptno 
order by d.deptnoselect * from dept d left join emp e on  d.deptno  = e.deptno
order by d.deptno

-- 如果是内连接 连表顺序无影响-- 如果做外联 连表顺序 有影响

多表关联时 全集方向保持一致

3.数据库对应关系 java对象对应关系

一对一情况下

java中 双方对象 都包含对方的对象 mybatis中使用 association 配置结果

一对多情况下

多方 包含一方的集合 collection配置

dept ----> list<emp>

class(班级) -----> list<student>

一方 关联多方的对象 association配置

emp -----> dept

student ---> class(班级)

多对多情况下

双方都是对方的集合 collection配置

order ----> list<productInfo>

productInfo -->list<Order>

总结:

java中 对象之间的关系

对象中包含某个其他对象 association

对象中包含集合其他对象 collection

4自连接

自连接 需要起别名 通过别名 让mybatis识别哪些是内层 哪些是外层

高级映射标签 association collection 可以多次 和嵌套使用

查省市对应关系数据

select ta2.*,ta1.code AS subcode ,ta1.name AS subname ,ta1.pcode AS subpcode  from tb_area ta1 inner join tb_area ta2 on ta1.pcode = ta2.code
where ta2.pcode = 0

映射文件

<resultMap id="TbAreaMap" type="com.javasm.entity.TbArea" ><id property="code" column="code" jdbcType="INTEGER"/><result property="name" column="name" jdbcType="VARCHAR"/><result property="pcode" column="pcode" jdbcType="INTEGER"/><collection property="subArea" ofType="com.javasm.entity.TbArea"><id property="code" column="subcode" jdbcType="INTEGER"/><result property="name" column="subname" jdbcType="VARCHAR"/><result property="pcode" column="subpcode" jdbcType="INTEGER"/></collection></resultMap>

查省市县对应关系数据

select ta3.*,ta2.code AS citycode ,ta2.name AS cityname ,ta2.pcode AS citypcode ,ta1.code AS areacode ,ta1.name AS areaname ,ta1.pcode AS areapcode  from tb_area ta1 inner join tb_area ta2 on ta1.pcode = ta2.codeinner join tb_area ta3 on ta2.pcode = ta3.code

映射文件

<resultMap id="TbAreaMap2" type="com.javasm.entity.TbArea" ><id property="code" column="code" jdbcType="INTEGER"/><result property="name" column="name" jdbcType="VARCHAR"/><result property="pcode" column="pcode" jdbcType="INTEGER"/><collection property="subArea" ofType="com.javasm.entity.TbArea"><id property="code" column="citycode" jdbcType="INTEGER"/><result property="name" column="cityname" jdbcType="VARCHAR"/><result property="pcode" column="citypcode" jdbcType="INTEGER"/><collection property="subArea" ofType="com.javasm.entity.TbArea"><id property="code" column="areacode" jdbcType="INTEGER"/><result property="name" column="areaname" jdbcType="VARCHAR"/><result property="pcode" column="areapcode" jdbcType="INTEGER"/></collection></collection></resultMap>


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/478834.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis设计与实现第14章 -- 服务器 总结(命令执行器 serverCron函数 初始化)

14.1 命令请求的执行过程 一个命令请求从发送到获得回复的过程中&#xff0c;客户端和服务器都需要完成一系列操作。 14.1.1 发送命令请求 当用户在客户端中输入一个命令请求的时候&#xff0c;客户端会把这个命令请求转换为协议格式&#xff0c;然后通过连接到服务器的套接字…

ArcGIS pro中的回归分析浅析(加更)关于广义线性回归工具的补充内容

在回归分析浅析中篇的文章中&#xff0c; 有人问了一个问题&#xff1a; 案例里的calls数据貌似离散&#xff0c;更符合泊松模型&#xff0c;为啥不采用泊松而采用高斯呢&#xff1f; 确实&#xff0c;在中篇中写道&#xff1a; 在这个例子中我们为了更好地解释变量&#x…

【面试题】2025年百度校招Java后端面试题

文章目录 前言一、网络IO1、服务器处理并发请求有哪几种方式&#xff1f;2、说一下select&#xff0c;poll&#xff0c;epoll的区别&#xff1f;3、Java 有一种现代的处理方式&#xff0c;属于异步I/O&#xff0c;是什么&#xff1f;redis&#xff0c;nginx&#xff0c;netty 是…

【Zookeeper 和 Kafka】为什么 Zookeeper 不用域名?

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

RiceChem——用于评估大语言模型在教育领域自动长答卷评分 (ALAG) 的数据集

摘要 论文地址:https://arxiv.org/abs/2404.14316 源码地址&#xff1a;https://github.com/luffycodes/automated-long-answer-grading 迄今为止&#xff0c;教育领域的自然语言处理&#xff08;NLP&#xff09;主要集中在简答题评分和自由文本作文评分方面。然而&#xff0c…

Java ArrayList 与顺序表:在编程海洋中把握数据结构的关键之锚

我的个人主页 我的专栏&#xff1a;Java-数据结构&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;点赞❤ 收藏❤ 前言&#xff1a;在 Java编程的广袤世界里&#xff0c;数据结构犹如精巧的建筑蓝图&#xff0c;决定着程序在数据处理与存储时的效率、灵活性以…

【04】Selenium+Python 手动添加Cookie免登录(实例)

一、什么是Cookie&#xff1f; Cookie 是一种由服务器创建并保存在用户浏览器中的小型数据文件。它用于存储用户的相关信息&#xff0c;以便在后续访问同一网站时可以快速检索这些信息。Cookie 主要用于以下几个方面&#xff1a; 1.状态管理&#xff1a; Cookie 可以保存用户…

GitLab|应用部署

创建docker-compose.yaml文件 输入docker-compose配置 version: 3.8 services:gitlab:image: gitlab/gitlab-ce:15.11.2-ce.0restart: alwayscontainer_name: gitlab-ceprivileged: truehostname: 192.168.44.235environment:TZ: Asia/ShanghaiGITLAB_OMNIBUS_CONFIG: |exter…

【PX4_Autopolite飞控源码】中飞控板初始化过程中的引脚IO控制(拉低/拉高)

先选择自己飞控板支持的硬件平台 打开对应的路径我的是Desktop/px4/PX4-Autopilot/boards/zhty/nora 找到board_config.h文件&#xff0c;打开nora后再往下去找Desktop/px4/PX4-Autopilot/boards/zhty/nora/src/borad_config.h 打开后可以看到有很多GPIO引脚的定义&#xff0c…

如何使用Postman优雅地进行接口自动加密与解密

引言 在上一篇文章中&#xff0c;分享了 Requests 自动加解密的方法&#xff0c;本篇文章分享一下更加方便的调试某个服务端接口。 Postman Postman 这个工具后端小伙伴应该相当熟悉了&#xff0c;一般情况下我们会在开发和逆向过程中使用它来快速向接口发送请求&#xff0c;…

Spring Boot——统一功能处理

1. 拦截器 拦截器主要用来拦截用户的请求&#xff0c;在指定方法前后&#xff0c;根据业务需要执行设定好的代码&#xff0c;也就是提前定义一些逻辑&#xff0c;在用户的请求响应前后执行&#xff0c;也可以在用户请求前阻止其执行&#xff0c;例如登录操作&#xff0c;只有登…

PYTORCH基础语法知识

初识Torch PyTorch&#xff0c;简称Torch&#xff0c;主流的经典的深度学习框架&#xff0c;深度学习的框架。 简介 PyTorch是一个基于Python的深度学习框架&#xff0c;它提供了一种灵活、高效、易于学习的方式来实现深度学习模型。PyTorch最初由Facebook开发&#xff0c;被…

C嘎嘎探索篇:栈与队列的交响:C++中的结构艺术

C嘎嘎探索篇&#xff1a;栈与队列的交响&#xff1a;C中的结构艺术 前言&#xff1a; 小编在之前刚完成了C中栈和队列&#xff08;stack和queue&#xff09;的讲解&#xff0c;忘记的小伙伴可以去我上一篇文章看一眼的&#xff0c;今天小编将会带领大家吹奏栈和队列的交响&am…

刷题日常(数据流中的中位数,逆波兰表达式求值,最长连续序列,字母异位词分组)

数据流中的中位数 描述 如何得到一个数据流中的中位数&#xff1f;如果从数据流中读出奇数个数值&#xff0c;那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值&#xff0c;那么中位数就是所有数值排序之后中间两个数的平均值。我们使用Insert()…

SQL 复杂查询

目录 复杂查询 一、目的和要求 二、实验内容 &#xff08;1&#xff09;查询出所有水果产品的类别及详情。 查询出编号为“00000001”的消费者用户的姓名及其所下订单。&#xff08;分别采用子查询和连接方式实现&#xff09; 查询出每个订单的消费者姓名及联系方式。 在…

uniapp-vue2引用了vue-inset-loader插件编译小程序报错

报错信息 Error: Vue packages version mismatch: - vue3.2.45 (D:\qjy-myApp\admin-app\node_modules\vue\index.js) - vue-template-compiler2.7.16 (D:\qjy-myApp\admin-app\node_modules\vue-template-compiler\package.json) This may cause things to work incorrectly.…

VOLO实战:使用VOLO实现图像分类任务(二)

文章目录 训练部分导入项目使用的库设置随机因子设置全局参数图像预处理与增强读取数据设置Loss设置模型设置优化器和学习率调整策略设置混合精度&#xff0c;DP多卡&#xff0c;EMA定义训练和验证函数训练函数验证函数调用训练和验证方法 运行以及结果查看测试完整的代码 在上…

【Linux】TCP网络编程

目录 V1_Echo_Server V2_Echo_Server多进程版本 V3_Echo_Server多线程版本 V3-1_多线程远程命令执行 V4_Echo_Server线程池版本 V1_Echo_Server TcpServer的上层调用如下&#xff0c;和UdpServer几乎一样&#xff1a; 而在InitServer中&#xff0c;大部分也和UDP那里一样&…

XG(S)-PON原理

前言 近年来&#xff0c;随着全球范围内接入市场的飞快发展以及全业务运营的快速开展&#xff0c;已有的PON技术标准在带宽需求、业务支撑能力以及接入节点设备和配套设备的性能提升等方面都面临新的升级需求XG(S)-PON(10G GPON)是在已有GPON技术标准上演进的增强下一代GPON技…

C语言学习 12(指针学习1)

一.内存和地址 1.内存 在讲内存和地址之前&#xff0c;我们想有个⽣活中的案例&#xff1a; 假设有⼀栋宿舍楼&#xff0c;把你放在楼⾥&#xff0c;楼上有100个房间&#xff0c;但是房间没有编号&#xff0c;你的⼀个朋友来找你玩&#xff0c;如果想找到你&#xff0c;就得挨…