首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MyBatis 实现关联表查询

一、一对一关联  1.1、提出需求   根据班级id查询班级信息(带老师的信息) 1.2、创建表和数据   创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系...,将查询结果自动封装成Classes对象返回 20 Classes clazz = sqlSession.selectOne(statement,1);//查询class表中id为1的记录...,将查询结果自动封装成Classes对象返回 36 Classes clazz = sqlSession.selectOne(statement,1);//查询class表中id为1的记录...所对应的外键字段名称 select:使用另一个查询封装的结果 二、一对多关联 2.1、提出需求   根据classId查询对应的班级信息,包括学生,老师 2.2、创建表和数据   在上面的一对一关联查询演示中...,将查询结果自动封装成Classes对象返回 20 Classes clazz = sqlSession.selectOne(statement,1);//查询class表中id为1的记录

2.8K140
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MyBatis学习总结(五)——实现关联表查询

    一、一对一关联 1.1、提出需求 根据班级id查询班级信息(带老师的信息) 1.2、创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系...,将查询结果自动封装成Classes对象返回 20 Classes clazz = sqlSession.selectOne(statement,1);//查询class表中id为1的记录...,将查询结果自动封装成Classes对象返回 36 Classes clazz = sqlSession.selectOne(statement,1);//查询class表中id为1的记录...select:使用另一个查询封装的结果 二、一对多关联 2.1、提出需求 根据classId查询对应的班级信息,包括学生,老师 2.2、创建表和数据 在上面的一对一关联查询演示中,我们已经创建了班级表和教师表...,将查询结果自动封装成Classes对象返回 20 Classes clazz = sqlSession.selectOne(statement,1);//查询class表中id为1的记录

    1.4K200

    MyBatis-Plus 如何实现连表查询

    MPJBaseServiceImpl (可选) 核心类 MPJLambdaWrapper和MPJQueryWrapper MPJLambdaWrapper用法 MPJLambdaWrapper示例 简单的3表查询...说明: UserDTO.class 查询结果返回类(resultType) selectAll() 查询指定实体类的全部字段 select() 查询指定的字段,支持可变参数,同一个select只能查询相同表的字段...t1,t2,t3… 条件查询,可以查询主表以及参与连接的所有表的字段,全部调用mp原生的方法,正常使用没有sql注入风险 分页查询 class test { @Resource private UserMapper...策略是覆盖,以最后一次为准,这里的策略是追加,可以一直select 主表字段可以用lambda,会自动添加表别名,主表别名默认是 t ,非主表字段必须带别名查询 leftJoin() rightJoin...() innerJoin() 传sql片段 格式 (表 + 别名 + 关联条件) 条件查询,可以查询主表以及参与连接的所有表的字段,全部调用mp原生的方法,正常使用没有sql注入风险 分页查询 class

    2.2K40

    Access生成表查询

    大家好前面已经介绍了选择查询、参数查询、交叉表查询,本节开始介绍操作查询部分内容。 操作查询用于多个记录执行批量操作,包括生成表查询、追加查询、更新查询和删除查询。 ?...在实际步骤中,操作查询依然可以套用前面介绍过的创建查询设计的步骤,只是需要选择查询类型,下面通过示例演示。 一、生 成 表 查 询 生成表查询:使用查询结果创建新的表。...生成表查询的意思可以从字面了解,通过该查询可以将查询的数据,创建成新的表。 二、示 例 演 示 下面通过示例来演示下生成表查询的步骤(和以前介绍的查询设计步骤相似。)...2、选择生成表查询 点击选项卡中查询类型的生成表,点击生成表,输入生成新表的表名称。(可以选择在当前数据库,或者另一数据库。) ? 之后可以点击运行来执行生成表,这里为了演示更多操作。...先点击保存该查询。 3、保存查询 在查询1处按鼠标右键,保存,将该生成表查询保存下来。(注意没有运行该查询,所以不会生成新的表格。),在导航窗格中查询类中可以看到带有感叹号的生成表查询的图标。

    2.3K10

    MySQL 分表查询

    下面将详细介绍MySQL如何分表以及分表后如何进行数据查询。 基于哈希的分表 基于哈希的分表是一种将数据分散到多个子表中的数据库分表策略。这种方法通过计算数据的哈希值来决定数据应该存储在哪个子表中。...基于哈希的分表可以帮助平均分布数据,提高查询性能,并减轻单个表的负载。下面是详细介绍如何基于哈希的分表的步骤: 步骤1:创建子表 首先,你需要创建多个子表,每个子表将存储一部分数据。...•查询性能: 基于哈希的分表通常适用于特定查询模式,如范围查询或特定条件查询。其他查询可能需要合并多个子表的结果,这可能会增加查询的复杂性和性能开销。...基于范围的分表 基于范围进行分表是一种数据库分表策略,它根据数据的范围条件将数据拆分到不同的子表中。这种方法适用于按时间、地理区域或其他有序范围进行查询的场景。...•查询路由算法: 查询路由算法应该与数据分布策略一致,以确保正确路由查询。 基于列表的分表 基于列表的分表是一种数据库分表策略,它根据某个列的值将数据分割到不同的子表中。

    1.1K20

    MySQL之单表查询、多表查询

    一、单表查询: 单个表的查询方法及语法顺序需要通过实际例子来熟悉 先将表数据创建下: ? ?...查询数据的条件依据 找到数据形成虚拟表 ②、where约束条件的使用 # 1.查询id大于等于3小于等于6的数据 mysql> select * from emp where id >=...多个表之间的查询一般都是在 表之间存在某种逻辑关联的情况下进行的查询,这种逻辑上的关联其实就是表中某个字段名和另外一个表中的字段名存在一个一一对应的关系或者关联。...| 2016-03-11 | +----+--------+--------+-----+---------+--------+-----------+------------+ 记住一个规律,表的查询结果可以作为其他表的查询条件...,也可以通过其别名的方式把它作为一张虚拟表去跟其他表做关联查询 额外题: 部门中薪资超过部门平均薪资的员工姓名及薪资 mysql> select t1.name,t1.salary,t1.post,t2

    22K30

    SQL92&SQL99实现三表联合查询

    deptno=30; update dept set loc=‘4’ where deptno=20; update dept set loc=‘4’ where deptno=10; –完成三表联合查询...–SQL92实现:查询员工信息及部门名称及所在城市名称并且员工的工资大于2000或者有奖金 –特点:易于书写,难于阅读 –缺点:92的SQL语句结构不清晰 –用法: –select 内容...(别名,连接符,去除重复,oracle函数,逻辑运算) –from 表名1,表名2,表名3… –where 条件(连接条件,普通筛选条件,where子句关键字) –group by 分组字段...c.cid and sal>2000) or (e.deptno=d.deptno and d.loc=c.cid and comm is not null) order by e.sal –SQL99实现...:查询员工信息及部门名称及所在城市名称并且员工的工资大于2000或者有奖金 –特点:难于书写,易于阅读 –使用: –select 内容 from 表名1 – inner join 表名2 –

    1.2K20

    MySQL如何实现分库分表,如何提高查询效率

    在大型电商网站中,随着业务的增多,数据库中的数据量也是与日俱增,这时候就要将数据库进行分库分表了。 1、如何分库分表?...两种解决方案:垂直拆分、水平拆分 垂直拆分:根据业务进行拆分,比如可以将一张表中的多个字段拆成两张表,一张是不经常更改的,一张是经常改的。...水平拆分:即根据表来进行分割:比如user表可以拆分为user0,、user1、user2、user3、user4等 2、分库分表之后如何实现联合查询?...可以使用第三方中间件来实现,比如:mycat、shading-jdbc 原理解析: 当客户端发送一条sql查询:select * from user;此时中间件会根据有几个子表,拆分成多个语句:select...* from user1;select * from user2;select * from user3等多条语句查询,然后将查询的结果返回给中间件,然后汇总给客户端。

    4.4K20
    领券