首页
学习
活动
专区
工具
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一次千万级查询优化

那么这SQL不优化直接第一次执行需要多久(这里强调第一次是因为MYSQL带有缓存功能,执行过一次的同样SQL,第二次会快很多。) ?...8、执行distinct去重复数据 9、执行order by字句 10、执行limit字句 这里得知,Mysql 是先执行内联然后再进行条件查询的最后再分组,那么想想这SQL的条件查询和分组都只是一个的...总结: 整个过程中我们得知,其实EXPLAIN有时候并不能指出你的SQL的所有问题,有一些隐藏问题必须要你自己思考,正如我们这个例子,看起来临时是最大效率低的源头,但是实际上9W的临时MYSQL来说不足以挂齿的...我们进行内联查询前,最好能限制大小的条件都先用上了,同时尽量让条件查询和分组执行的尽量小。感谢您们的阅读,如果有更好的方案,欢迎留言交流!!! 估计到这里,你猜这里就是全部的优化方案?...总结: 其实这个优化方案跟我上一篇文章MYSQL一次千万级查询优化(一)解决原理一样,都是解决了内联后数据就变得臃肿了,这时候再进行条件查询和分组就太吃亏了,于是我们可以先对单进行条件处理,再进行查询

3.5K40

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

sql server 连接查询_查询语句

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

3.4K10

MySQLupdate操作

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

4.2K30

MyBatis-Plus 如何实现查询

MPJBaseServiceImpl (可选) 核心类 MPJLambdaWrapper和MPJQueryWrapper MPJLambdaWrapper用法 MPJLambdaWrapper示例 简单的3查询...说明: UserDTO.class 查询结果返回类(resultType) selectAll() 查询指定实体类的全部字段 select() 查询指定的字段,支持可变参数,同一个select只能查询相同的字段...: 参与的实体类class 第二个参数: 的ON字段,这个属性必须是第一个参数实体类的属性 第三个参数: 参与的ON的另一个实体类属性 默认主表别名是t,其他的别名以先后调用的顺序使用...t1,t2,t3… 条件查询,可以查询主表以及参与连接的所有的字段,全部调用mp原生的方法,正常使用没有sql注入风险 分页查询 class test { @Resource private UserMapper...() innerJoin() 传sql片段 格式 ( + 别名 + 关联条件) 条件查询,可以查询主表以及参与连接的所有的字段,全部调用mp原生的方法,正常使用没有sql注入风险 分页查询 class

1.7K40

MySQL查询

是一种数据库分割技术,用于将大拆分成多个小,以提高数据库的性能和可管理性。在MySQL中,可以使用多种方法进行分,例如基于范围、哈希或列表等。...下面将详细介绍MySQL如何分以及分后如何进行数据查询。 基于哈希的分 基于哈希的分是一种将数据分散到多个子表中的数据库分策略。这种方法通过计算数据的哈希值来决定数据应该存储在哪个子表中。...基于哈希的分可以帮助平均分布数据,提高查询性能,并减轻单个的负载。下面是详细介绍如何基于哈希的分的步骤: 步骤1:创建子表 首先,你需要创建多个子表,每个子表将存储一部分数据。...示例插入数据: -- 计算数据的哈希值(示例使用MySQL的MD5哈希函数) SET @hash = MD5(CONCAT(customer_id, order_date)); -- 根据哈希值决定插入到哪个子表中...•查询路由算法: 查询路由算法应该与数据分布策略一致,以确保正确路由查询。 基于列表的分 基于列表的分是一种数据库分策略,它根据某个列的值将数据分割到不同的子表中。

63320

Mysql使用left join查询时,因连接条件未加索引导致查询很慢

背景 最近一个后台功能列表,业务人员反馈查询和导出速度非常慢。 通过定位发现列表查询和数据导出都是使用的同样的一个查询SQL。...排查 通过Explain发现,查询中的table c没有使用到索引且是全扫描。另外在Extra中特别说明了Using join buffer (Block Nested Loop)。...知识延伸 MySQL使用嵌套循环算法或其变种来进行之间的连接。 在5.5版本之前,MySQL只支持一种间关联方式,也就是嵌套循环(Nested Loop)。...如果关联的数据量很大,那么join关联的时间会很长。在5.5版本以后,MySQL引入了BNL算法来优化嵌套循环。...由于索引的效率要比逐条循环效率高,所以当使用索引联时,能大大加快查询速度,但是索引也不是万能的,如果你需要取索引以外的字段,那么依旧需要回到中查出相应的数据。

2.3K10

数据库之查询_数据库怎么查询的内容

什么是多表关联查询? 有时一个查询结果需要从两个或两个以上表中提取字段数据,此时需要使用的就是多表关联查询。 链接查询主要分为三种:内连接、外连接、交叉连接。...<)进行间的比较操作,查询与连接条件相匹配的数据。根据所使用的比较方式不同,内连接分为等值连接、自然连接和自连接三种。...关键字:INNER JOIN 1.等值连接/相等连接: 使用”=“关系将连接起来的查询,其查询结果中列出被连接中的所有列,包括其中的重复列 2.自然连接 等值连接中去掉重复的列,形成的链接。...3.自连接 如果在一个连接查询中,涉及到的两个是同一个,这种查询称为自连接查询。...2.右外连接 关键字:RIGHT[OUTER]JOIN 返回右中的所有行,如果右中行在左中没有匹配行,则在左中相关字段返回NULL值。

5.6K20

MySQL之单查询、多表查询

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

22K30
领券