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

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.5K30

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 条件表达式:用来分组查询后指定一些条件来输出查询结果

3.8K90
您找到你想要的搜索结果了吗?
是的
没有找到

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

3.7K30

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一次千万级查询优化(一)解决原理一样,都是解决了内联后数据就变得臃肿了,这时候再进行条件查询分组就太吃亏了,于是我们可以先对单进行条件处理,再进行查询

3.5K40

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查询总结

3.3K20

sql server 连接查询_查询语句

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

3.4K10

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的区别,一个是正向,一个是反向

2.4K40

MySQL(八)子查询分组查询

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

3.6K20

MySQLupdate操作

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

4.2K30

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

1.8K30

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

分组后排序 需求:获取每个⽤户最⼤⾦额,然后按照最⼤⾦额倒序,输出:⽤户id,最⼤⾦额,如 下: mysql> SELECT user_id ⽤户id, max(price) 最⼤⾦额 FROM...where [查询条件] group by [分组表达式] having [分组过滤条件]order by [排序条件] limit [offset,] count; 注意: 写法上⾯必须按照上⾯的顺序来写...⽰例: 需求:查询出2018年,下单数量⼤于等于2的,按照下单数量降序排序,最后只输出第1 条记录,显⽰:⽤户id,下单数量,如下: mysql> SELECT user_id ⽤户id, COUNT...建议:在写分组查询的时候,最好按照标准的规范来写,select后⾯出现的列必须在 group by中或者必须使⽤聚合函数。 总结 1....在写分组查询的时候,最好按照标准的规范来写,select后⾯出现的列必须在group by中或者必须使⽤聚合函数。

1.8K10
领券