首页
学习
活动
专区
圈层
工具
发布

MySQL连表查询练习题

个人博客:"DBA老司机带你删库跑路" 建库 库名:linux50 字符集:utf8 校验规则:utf8_general_ci  建表 ---- 表一 表名:student(学生表) 字段...(数据自定义) 2.将曾导、徐导、李导信息插入教师表中(数据自定义) 3.将数学、语文、英语学科插入到课程表中(数据自定义) 4.将分数插入到成绩表中(数据自定义) 查询练习: 1.查询student表中的所有记录的...2.查询教师所有的单位即不重复的depart列。 3.查询student表的所有记录。 4.查询score表中成绩在60到80之间的所有记录。 5.查询score表中成绩为85,86或88的记录。...6.查询student表中1班或性别为“女”的同学记录。 7.以class降序查询Student表的所有记录。 8.以cno升序、mark降序查询Score表的所有记录 9.查询2班的学生人数。...10.查询”曾志高翔“教师任课的学生成绩。 11.查询语文课程所有男生的成绩并且查出对应课程的教师名,职称,及所在部门。 12.把11题查出的成绩按照降序排序。

1.9K30

MySQL分组查询

概述MySQL分组查询是数据库操作中的一种常用操作,用于对数据进行分组统计。...在MySQL中,分组查询主要通过GROUP BY子句实现,GROUP BY子句用于对查询结果进行分组,然后通过聚合函数对每个分组进行统计。本文将介绍MySQL分组查询的基本语法和常用操作。...理解(先分组,再统计)根据一个字段进行分组: 假设现在有一个用户表,表中有10条数据,我们根据性别把所有的数据进行分组,可以分成2组,每组5条数据。...,aggregate_function为聚合函数,table_name为表名,condition为筛选条件。...-- GROUP BY子句用于对查询结果进行分组,HAVING子句用于筛选分组后的结果。过滤分组(HAVING)HAVING 用于筛选分组后的结果,只有满足条件的分组才会被返回。

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

    mysql分组查询

    group by (1) group by的含义:将查询结果按照1个或多个字段进行分组,字段值相同的为一组 (2) group by可用于单个字段分组,也可用于多个字段分组 select * from...1001 | 张三 | 26 | 男 | beijinghdq | +------+------+--------+------+------+------------+ 根据sex字段来分组...只显示出每组的第一条记录 所以group by单独使用时的实际意义不大 group by + group_concat() (1) group_concat(字段名)可以作为一个输出字段来使用, (2) 表示分组之后...,根据分组结果,使用group_concat()来放置每一组的某字段的值的集合 select sex from employee group by sex; +------+ | sex | +---...女 | 1 | | 男 | 3 | +------+------------+ group by + having (1) having 条件表达式:用来分组查询后指定一些条件来输出查询结果

    5.1K90

    MYSQL一次千万级连表查询优化

    网上搜索得知内联表查询一般的执行过程是: 1、执行FROM语句 2、执行ON过滤 3、添加外部行 4、执行where条件过滤 5、执行group by分组语句 6、执行having 7、select列表...8、执行distinct去重复数据 9、执行order by字句 10、执行limit字句 这里得知,Mysql 是先执行内联表然后再进行条件查询的最后再分组,那么想想这SQL的条件查询和分组都只是一个表的...,内联后数据就变得臃肿了,这时候再进行条件查询和分组是否太吃亏了,我们可以尝试一下提前进行分组和条件查询,实现方法就是子查询联合内联查询。...我们进行内联查询前,最好能限制连的表大小的条件都先用上了,同时尽量让条件查询和分组执行的表尽量小。感谢您们的阅读,如果有更好的方案,欢迎留言交流!!! 估计到这里,你猜这里就是全部的优化方案?...总结: 其实这个优化方案跟我上一篇文章MYSQL一次千万级连表查询优化(一)解决原理一样,都是解决了内联表后数据就变得臃肿了,这时候再进行条件查询和分组就太吃亏了,于是我们可以先对单表进行条件处理,再进行连表查询

    4K51

    Mysql约束、分组查询

    tip: 通过 desc 表名命令查看当前表信息 tip2: as 关键字可以为我们的字段或者表取别名 Mysql约束 顾名思义就是对表中的数据进行限定, 目的是保证数据的正确性, 有效性和完整性 主键约束...primary key 什么是主键 关系表中记录的唯一标识(不能为null, 不可重复) 选取和业务无关的字段, 常用的主键就是自增id 数据库引擎会通过主键建立索引, 索引是一个有序结构, 我们希望当前主键的值不要改变...添加主键 建表时添加 CREATE TABLE store_perf( id int PRIMARY KEY auto_increment, store_name varchar(255) ) 通过可视化界面操作...扩展性问题 外键就相当于把对象之间的关系交给数据库来维护, 如果遇到分库分表, 外键是不生效的. 作数据迁移时, 触发器, 存储过程和外键都很难迁移, 增加了维护成本....如果我们没有给一个有默认约束的字段create_time值, 那么该字段会默认填充CURRENT_TIMESTAMP 分组查询GROUP BY 将数据按某个字段进行分组, 配合SUM, AVG, COUNT

    4.7K30

    【MySQL】聚合查询 和 分组查询

    一、聚合查询 1.概念 聚合查询:是SQL中对数据进行分组统计的操作,可以将多行数据按照特定条件合并计算,返回汇总结果。...1.GROUP BY子句 定义 定义:GROUP BY是SQL中用于分组聚合的核心子句,用于将查询结果按照一个或多个列的值进行分组,把具有相同列值的行归为一组。...(需要的运算的列),如果要显示结果,需要用到聚合函数; group by:分组查询的关键字; column1:要分组的列名。...对分组后的结果进行筛选 使用限制 不能使用聚合函数 可以使用聚合函数 三、插入查询结果 插入查询结果:把一个表中的数据插入到另一个表中 语法 insert into table_name [(column1...示例: 将旧学生表1中的学生姓名插入到另一个表中 -- 查看旧表学生表1找你中的信息: mysql> select * from students; +----------+--------+ | class_id

    61410

    mysql连接查询与分组查询

    连表查询在项目中用的很频繁,今天在这里总结一下 假设两张表 user: id name dept_id dept: id dept_name 交叉连接(cross join) 交叉连接是一个笛卡尔积的结果...查询的结果中两个语句重复的数据会被合成一条,如果要显示重复的记录,就需要使用 union all 全连接(full join) 我查了一下资料,mysql并不支持全连接(full join)这个功能,...但是可以通过left join、right join、union实现全连接 备注: union 操作用来联合两个查询结果(不包含重复值) union all 联合的结果包含重复值 还是上面例子的两个表t1...from t1 left join t2 on t1.t1id = t2.t2id t1id t1str t2id t2str 1 1 null null 2 2 2 a 3 3 3 b 参考资料 mysql...多表查询 mysql联表查询总结

    5.2K20

    Mysql查询语句之连表查询和增删改查语句补充

    查询 我们的数据是这样的。 ? 发现class_id是一个数字,这是因为我们在设计时,将学生表和班级表分开设计的。 ? 但是如果我们偏偏想要查询这个人是几班的,怎么办?...连表查询 方式一,where连表 语法 SELECT * from 表1,表2 WHERE 表1.外键列=表2.被外键列; SELECT 表1.列1,表1.列2,表2.列1,... from 表1,表2...在一般连表操作中,使用的也是left进行连表。...其实这和where连表是一样的。 方式三,inner连表 inner和left是差不多的,只不过left是正向连表,inner是反向连表。 就像学生表和课程表。...总结 这章有点像收尾部分,补充了连表查询,后续又补充了Mysql的增删改查。 连表查询要区分一下left和inner的区别,一个是正向连,一个是反向连。

    3K40

    sql server 连接查询_连表查询语句

    SQL的连表查询 2017年08月31日 15:58:49 SQL的连表查询 连接查询包括合并、内连接、外连接和交叉连接,如果涉及多表查询,了解这些连接的特点很重要。...两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 注意:使用UNION时,两张表查询的结果有相同数量的列、列类型相似。...(内连接),也成为自然连接 作用:根据两个或多个表中的列之间的关系,从这些表中查询数据。...会把两个表所有的行都显示在结果表中 1)使用全连接查询学生的信息,其中包括学生ID,学生姓名和专业名称。...交叉连接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉连接也称作笛卡尔积。 简单查询两张表组合,这是求笛卡儿积,效率最低。 笛卡儿积:笛卡尔乘积,也叫直积。

    4.8K10

    MySQL(八)子查询和分组查询

    (实际上,MySQL执行了2个select操作),where子句中使用子查询,必须保证select语句具有与where子句中相同数目的列;   子查询一般与in操作符结合使用,但也可用于测试等于(=)、...表和usertable表中的user_id列。...相关子查询(correlated subquery):涉及外部查询的子查询(任何时候只要列名可能存在多叉性,就必须使用这种语法[表名和列名有一个句点分隔])。...PS:使用子查询建立查询的最可靠方法是逐渐进行(首先建立最内层的查询,确认后用硬编码数据建立外层查询,由内到外) 二、组合查询 MySQL允许执行多个查询(多条select语句),并将结果作为单个查询结果集返回...以下两种基本情况,需要使用组合查询: ①在单个查询中从不同表返回类似结构的数据; ②对单个表执行多个查询,按单个查询返回数据; 1、union union可将多条select语句的结果组合成单个结果集,

    5K20

    MySQL连表update操作

    MySQL连表update操作 一、介绍 记录一下MySQL连表后进行update的操作,这可以一口气同时改动到多张表的数据,可以取到关联表的数据进行更新。...; 模型如下图 2)连表更新 如果班级里张三比较调皮,在班级座位后面睡觉被校长发现了,要把这位学生和所在班级的评分,各扣10分 如果是以前,我可能是写两条update语句的sql,现在的话,可以关联起来这样写...,如下 ---- 首先我们可以先写一个这样的sql,通过学生名称查询到学生分数,所在班级分数,那么这条sql就长这样 select t1.grade as "学生分数", t2.grade as...`name` = '张三'; ---- 那么此时,我们只需要做一点小小的改动,就可以把上述sql改为连表update的了。...`name` = '张三'; 执行完成就可以了,再查询看看效果 三、最后 我是半月,你我一同共勉!!!

    5.3K30

    MySQL学习,详解分组查询(一)

    分组查询 语法: SELECT column, group_function,......分组前对数据进⾏筛选,使⽤where关键字 需求:需要查询2018年每个⽤户下单数量,输出:⽤户id、下单数量,如下: mysql> SELECT user_id ⽤户id, COUNT(id)...分组后对数据筛选,使⽤having关键字 需求:查询2018年订单数量⼤于1的⽤户,输出:⽤户id,下单数量,如下: ⽅式1:mysql> SELECT user_id ⽤户id, COUNT(id...(聚合)前对记录进⾏筛选,⽽having是在分组结束后的结果⾥筛选,最 后返回整个sql的查询结果。...可以把having理解为两级查询,即含having的查询操作先获得不含having⼦句时的sql查询 结果表,然后在这个结果表上使⽤having条件筛选出符合的记录,最后返回这些记录,因 此,having

    2.1K30
    领券