目录
既然数据库是存储项目中的数据的,项目中的数据主要是类型创建的对象,项目中类型和类型之间是有关系的,数据库中怎么体现出来?
不论是生活中,还是抽象出来的软件中,描述生活中的多个类型之间的关系,总结如下:
举例:
学生和成绩就是一对多 成绩和学生就是一对一
一个学生可以有多个成绩 多个成绩属于同一个学生
人和身份证号就是一对一
一个人只能有一个身份证号 一个身份证号只能属于一个人
老师和学生之间就是多对多
一个学生可以被多个老师教过 一个老师可以交多个学生
特例:
一个学生,他都只能有一个班级。
所以Mybatis就把多对一(多个学生对一个班级)看成了一对一。
示例:学生和班级
一个班级可以有多个学生
一个学生只能属于一个班级(多个学生也可以属于同一个班级)
步骤:
1、建立两张表:学生表,班级表
让学生表和班级表之间具备一对多的关系:需要使用外键在学生表中添加
2、建立两个实体类:学生实体类和班级实体类
让学生和班级的实体类能体现出来一对多的关系
3、建立两个配置文件
学生的配置文件
班级的配置文件
4、实现配置:
当我们查询学生时,可以同时得到学生所对应的班级信息
当我们查询班级时,可以同时得到班级的所属学生信息
student(学生表)

class(班级表)

实体类(有参无参getset方法以及tostring)



需求:
查询所有学生,同时还要获取当前学生的所属班级信息。
注意:
因为一个学生信息只能提供一个班级,所以从查询学生信息出发关联查询班级信息为一对一查询。如果从班级信息出发查询每个班级下的学生信息则为一对多查询,因为一个班级可以有多个学生。
创建StudengMapper接口

对应的xml映射文件

注意:接口名与xml映射文件名一致
多对一/一对一使用<association>标签
在编写Sql语句注意:
实现查询学生信息时,也要查询学生所对应的班级信息。
select * from student inner join class on student.classid=class.classid

创建studentMapper接口 与对应ClassMapper所对应的方法
public interface StudentMapper {
//多对一/一对一映射 @One(Select="能得到属性对象的反射字符串 包.类.方法名",fetchType)
//联查两表 要有跟那个表对应的属性 classid去映射Class表的单查
@Results({
@Result(column = "classid",property ="classid" ),
@Result(column = "classid",property = "bj",
one = @One(select = "com.ape.mapper.ClassMapper.findClassByclassid"))
})
@Select("select * from student")
public List<Student> findAllStudent();
@Select("select * from student where classid=#{classid}")
public Student findStudentByClassid(int classid);
}
public interface ClassMapper {
@Select("select * from Class where classid=#{classid}")
public Class findClassByclassid(int classid);
}
注意:
@Results只修饰下面所遇见的第一个方法,别的方法需要映射需要@ResultMap(id="")去调用
查询结果:

需求:
查询所有班级,同时还要获取当前班级的所属学生信息。
注意:
班级信息和他的学生信息为一对多关系,并且查询过程中如果班级没有学生信息,此时也要将学生信息查询出来,我们想到了左外连接查询比较合适。
实体类注意:

班级里有多个学生对应需要有学生集合的属性。
创建ClassMapper接口
package com.ape.mapper;
import java.util.List;
import com.ape.bean.Class;
public interface ClassMapper {
public List<Class> findAllClass();
}
同名xml映射文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ape.mapper.ClassMapper">
<resultMap type="Class" id="Class_Stu_Map">
<result column="classid" property="classid"/>
<result column="classname" property="classname"/>
<collection property="slist" ofType="Student">
<result column="sid" property="sid"/>
<result column="sname" property="sname"/>
<result column="birthday" property="birthday"/>
<result column="ssex" property="ssex"/>
<result column="classid" property="classid"/>
</collection>
</resultMap>
<select id="findAllClass" resultMap="Class_Stu_Map">
select * from class left join student on student.classid=class.classid
</select>
</mapper>
注意:接口名与xml映射文件名一致
一对多/多对多使用<collection>标签
在编写Sql语句注意:
实现查询班级信息时,也要查询班级所对应的学生信息。
select * from class left join student on student.classid=class.classid
查询结果:

创建ClassMapper接口 与对应StudentMapper所对应的方法
package com.ape.mapper;
import java.util.List;
import org.apache.ibatis.annotations.Many;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;
import com.ape.bean.Class;
public interface ClassMapper {
//一对多 用many=@Many(select="包名.类名.方法名")
@Results({
@Result(column = "classid",property = "classid"),
@Result(column = "classid",property = "slist",
many = @Many(select="com.ape.mapper.StudentMapper.findStudentByClassid"))
})
@Select("select * from Class")
public List<Class> findAllClass();
package com.ape.mapper;
import java.util.List;
import org.apache.ibatis.annotations.One;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;
import com.ape.bean.Student;
public interface StudentMapper {
@Select("select * from student where classid=#{classid}")
public Student findStudentByClassid(int classid);
}
注意:
一对多 用many=@Many(select="包名.类名.方法名")
查询结果:

以上就是Mybatis的多表关联查询(一对一、一对多)的全部内容。
看完如果对你有帮助,感谢点赞支持!
如果你是电脑端的话,看到右下角的 “一键三连” 了吗,没错点它[哈哈]
加油!
共同努力!
我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
MIMO技术的优缺点优点通过下面三个增益来总体概括:阵列增益。阵列增益是指由于接收机通过对接收信号的相干合并而活得的平均SNR的提高。在发射机不知道信道信息的情况下,MIMO系统可以获得的阵列增益与接收天线数成正比复用增益。在采用空间复用方案的MIMO系统中,可以获得复用增益,即信道容量成倍增加。信道容量的增加与min(Nt,Nr)成正比分集增益。在采用空间分集方案的MIMO系统中,可以获得分集增益,即可靠性性能的改善。分集增益用独立衰落支路数来描述,即分集指数。在使用了空时编码的MIMO系统中,由于接收天线或发射天线之间的间距较远,可认为它们各自的大尺度衰落是相互独立的,因此分布式MIMO
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
我正在尝试查询我的Rails数据库(Postgres)中的购买表,我想查询时间范围。例如,我想知道在所有日期的下午2点到3点之间进行了多少次购买。此表中有一个created_at列,但我不知道如何在不搜索特定日期的情况下完成此操作。我试过:Purchases.where("created_atBETWEEN?and?",Time.now-1.hour,Time.now)但这最终只会搜索今天与那些时间的日期。 最佳答案 您需要使用PostgreSQL'sdate_part/extractfunction从created_at中提取小时
通常,数组被实现为内存块,集合被实现为HashMap,有序集合被实现为跳跃列表。在Ruby中也是如此吗?我正在尝试从性能和内存占用方面评估Ruby中不同容器的使用情况 最佳答案 数组是Ruby核心库的一部分。每个Ruby实现都有自己的数组实现。Ruby语言规范只规定了Ruby数组的行为,并没有规定任何特定的实现策略。它甚至没有指定任何会强制或至少建议特定实现策略的性能约束。然而,大多数Rubyist对数组的性能特征有一些期望,这会迫使不符合它们的实现变得默默无闻,因为实际上没有人会使用它:插入、前置或追加以及删除元素的最坏情况步骤复