Mysql数据库-子查询 1. 什么是子查询 # 子查询定义 ## B语句作为A语句的一部分,B语句是select查询语句,那么B语句称之为子查询,内层查询(子集,subquery) -- 1....查询emp表的最高工资salary,然后再根据最高工资salary查询员工的信息 -- 2.1 通过max(salary)可以查询出emp表的最高工资为9000 mysql> select max(salary...查询部门平均工资超过全公司平均工资的部门id和部门平均工资 -- 3.1 先查询公司平均工资 mysql> select avg(salary) from emp; +-----------------...查询工资大于5000的员工,来自于哪些部门的名字 -- 1.1 首先查询salary>5000的部门ID,列子查询(多行单列) mysql> select dept_id from emp where...查询开发部与财务部所有的员工信息 -- 2.1 查询出 开发部 与 财务部 的部门ID mysql> select id from dept where name = '开发部' or name = '
MySQL发送查询请求,到底做了什么工作? 下图是MySQL查询执行流程图: ? •客户端发送一条查询给服务器。•服务器先检查查询缓存,如果命中了缓存,则立刻返回查询在缓存中的结果。...•MySQL根据优化器生成的执行计划,调用存储引擎的API来执行查询。•将结果返回给客户端。 是什么导致MySQL查询变慢了?...2.多表关联时返回全部列 3.总是取出全部列 常用优化技巧 1.用索引 最简单且见效最快的方式就是给你的条件加索引(主键索引,普通索引,唯一索引等)。...2.关联子查询 MySQL的子查询实现是非常糟糕的。...每个 SELECT 都会自动分配一个唯一的标识符.•select_type: SELECT 查询的类型.
MYSQL数据库-复合查询 零、前言 一、基本查询 二、多表查询 三、自连接 四、子查询 1、单行子查询 2、多行子查询 3、多列子查询 3、在from子句中使用子查询 五、合并查询 1、union 2...、union all 零、前言 本章主要讲解学习MYSQL数据库中的复合查询,前面我们讲解的mysql表的查询都是对一张表进行查询,在实际开发中这远远不够 一、基本查询 示例: 查询工资高于500...worker,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别 四、子查询 子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 1、单行子查询 返回一行记录的子查询...,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句 示例:查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人 3、在from...子句中使用子查询 子查询语句出现在from子句中。
SQL语句,子查询被嵌入到一对小括号里面 数据库设计之三范式 1、数据库设计之三范式的介绍 范式: 对设计数据库提出的一些规范,目前有迹可寻的共有8种范式,一般遵守3范式即可。...5、E - R模型的介绍 E-R模型即实体-关系模型,E-R模型就是描述数据库存储数据的结构模型。...E-R模型由 实体、属性、实体之间的关系构成,主要用来描述数据库中表结构。...开发流程是先画出E-R模型,然后根据三范式设计数据库中的表结构 外键SQL语句的编写 1、外键约束作用 外键约束:对外键字段的值进行更新和插入时会和引用表中字段的数据进行验证,数据如果不合法则更新和插入会失败...create database jing_dong charset=utf8; -- 使用 "京东" 数据库 use jing_dong; -- 创建一个商品goods数据表 create table
概述 分组查询的作用是将查询的结果按指定字段分组,字段中数值相等的为一组。 分组以后可以配合count()、agv()、sum()、max()等聚合函数使用。...语法 group by 列名 [having表达式][with rollup] having表达式:用来过滤分组后的数据 with rollup:在所记录后加一条,显示select查询聚合的结果 案例
概述 使用where子句实现对查询数据的筛选 where子句分为五类: 比较运算符 逻辑运算符 范围查询 模糊查询 空判断 语法 select 字段名from 表名 where子句; 分类 比较运算符筛选...= 逻辑运算符 and or not 范围查询 in between 大 and 小 模糊查询 like 查询关键字 %表示任意多个字符(包括0) _表示任意一个字符 escape:取消%或_字符的通配符特性
MySql版本信息的查询: 1、通过mysql -V命令查询 C:/mysql/bin>mysql -V mysql Ver 12.22 Distrib 4.0.18, for Win95/Win98...(i32) 2、通过mysql模式下的status命令查看状态 mysql> status -------------- mysql Ver 12.22 Distrib 4.0.18, for Win95...> 3、通过mysql模式下的select语句查询 mysql> select version(); +-----------+ | version() | +-----------+ | 4.0.18...-nt | +-----------+ 1 row in set (0.00 sec) mysql> 4、通过mysql --help命令进行查看 C:/mysql/bin>mysql --help mysql... Ver 12.22 Distrib 4.0.18, for Win95/Win98 (i32) Copyright (C) 2002 MySQL AB
概述: 连接查询的作用将多张表进行内容上的连接,查看数据时可以同时看到多张表的多个数据 连接查询的分类 内连接查询 左连接查询 右连接查询 自连接查询 语法 #内连接 SELECT * FROM...inner join 实现多表查询,查询共有记录。...SELECT * FROM 表1 inner join 表2 on 表1.字段=表2.字段 左连接查询 left join 以左表为主,查询右表的数据。若右表不存在数据,则返回null。...SELECT * FROM 表1 left join 表2 on 表1.字段=表2.字段 右连接查询 right join 以右表为主,查询左表的数据。若左表不存在数据,则返回null。...SELECT * FROM 表1 right join 表2 on 表1.字段=表2.字段 自连接查询 inner join 左表和右表是同一个表,查询两个表中的数据。
单表查询 1、普通查询 (1)命令:select * from ;//通匹 (2)命令:select 查询的字段> from ; 2、去重查询(distinct) 命令:select...distinct 查询的字段> from 3、排序查询(order by) 升序:asc 降序:desc 降序排列命令:select 查询的字段名> from order...要求查询一个学生的总成绩。我们根据学号将他们分为了不同的组。...命令:mysql>select id, Sum(score) from result group by id; 多表查询 一、等值查询 现在有两个表: 现在要查询年龄小于20岁学生的不及格成绩...: 可见等值查询效率太低 二、连接查询 1、外连接查询 (1)左外连接查询 假设我们依旧使用的是上面的两个表,任然查询年龄小于20岁学生的不及格成绩 我们利用左外连接查询,先将学生表中所有年龄小于
图片目录数据库的基本查询 DQL简单查询聚合查询分组查询排序查询分页查询数据库的基本查询 DQL简单查询--查询所有的商品 select * from 表名;-...-查询商品名和商品价格 select 列名1,列名2 from 表名;--别名查询使用关键字as(as可以省略) select * from 表名 as 别名;select...列名 as 别名 from 表名;--去掉重复值(distinct) select distinct 列名 from 表名;--查询结果是表达式(运算查询)...MySQL提供了许多聚合函数,包括 AVG , COUNT , SUM , MIN , MAX 等。. 除 COUNT 函数外,其它聚合函数在执行计算时会忽略 NULL 值。...LIMIT子句除外 分页查询 分页查询在项目开发中常见,由于数据量很大,显示屏长度有限,因此对数据需要采取分页显示方式。
以大小写输入关键词查询是等价的,比如SELECT=select。...(4)mysql接受自由格式的输入:它收集输入行但直到看见分号才执行。 (5)要注意提示符如何从mysql>变为->,这正是mysql如何指出它没见到完整的语句并且正在等待剩余的部分。...提示符是你的朋友,因为它提供有价值的反馈,如果使用该反馈,将总是知道mysql正在等待什么。
> select * from stu where ch>=60; -- 查询语文和数学都及格的学生 mysql> select * from stu where ch>=60 and math>=60...; -- 查询语文或数学不及格的学生 mysql> select * from stu where ch<60 or math<60; 思考:如下语句输出什么?...* from stu where stuaddress in ('北京','上海'); -- 查询不是北京和上海的学生 mysql> select * from stu where stuaddress...】 将查询的结果分组,分组查询目的在于统计数据。...-- 查询男生和女生的各自语文平均分 mysql> select stusex,avg(ch) '平均分' from stu group by stusex; +--------+---------+
SELECT 子查询 子查询( subquery)即嵌套查询 ,嵌套在其他查询中的查询。...查询粉丝数大于400的用户的作者QQ号 select name,au_id,qq from Author where au_id in(select au_id from Article where...count(*) from ArticleDetail where ArticleDetail.ar_id=Article.ar_id) as '文章数目' from Article; SELECT 多表查询...查询每篇文章的阅读次数,所属类型,作者 select ArticleDetail.title,ArticleDetail.reade_times,Article.type,Article.author...from ArticleDetail,Article where ArticleDetail.ar_id=Article.ar_id ; 查询文章粉丝数大于400的所有文章类型及作者姓名,QQ select
数据操作语言:普通查询 记录查询 最基本的查询语句是由 SELECT 和 FROM 关键字组成的 SELECT * FORM t_emp; SELECT empnpo, ename, sal FROM...用户不必关心数据的真实存储,交由数据库高效的查找数据 USE demo; SELECT * FROM t_emp; SELECT empno,ename,sal FROM t_emp; 使用列命名 通常情况下...SELECT empno, sal*12 AS "income" FROM t_emp; SELECT empno,sal*12 AS "icome" FROM t_emp; 查询语句的子句执行顺序
1.3 子查询 语法:select * from 表1 where (子查询) 外面的查询称为父查询 子查询为父查询提供查询条件 1.3.1 标量子查询 特点:子查询返回的值是一个 -- 查找笔试成绩是...特点: 子查询返回的结果是一列 如果子查询的结果返回多条记录,不能使用等于,用in或not in -- 查找及格的同学 mysql> select * from stuinfo where stuno...特点:子查询返回的结果是多个字段组成 -- 查找语文成绩最高的男生和女生 mysql> select * from stu where(stusex,ch) in (select stusex,max...特点:将子查询的结果作为表 -- 查找语文成绩最高的男生和女生 mysql> select * from (select * from stu order by ch desc) t group by...1.3.5 exists子查询 -- 如果笔试成绩有人超过80人,就显示所有学生信息 mysql> select * from stuinfo where exists (select * from
1.2 多表查询 1.2.1 内连接 规则:返回两个表的公共记录 语法: -- 语法一 select * from 表1 inner join 表2 on 表1.公共字段=表2.公共字段 -- 语法二...select * from 表1,表2 where 表1.公共字段=表2.公共字段 例题 -- inner join mysql> select * from stuinfo inner join stumarks...--+------------+---------+--------+-------------+---------+ 5 rows in set (0.00 sec) -- 相同的字段只显示一次 mysql...-------+------------+---------+--------+-------------+---------+ 5 rows in set (0.00 sec) -- 如何实现三表查询...| | 上海 | | 天津 | +------------+ 3 rows in set (0.00 sec) 3、显示男生和女生的人数 -- 方法一: 分组查询
1. 1 mysql> describe tmp_log; 2 +----------+------------------+------+-----+---------+--------------...-------+------------------+------+-----+---------+----------------+ 9 3 rows in set (0.01 sec) 2 1 mysql...Key: 21 Default: 22 Extra: 23 3 rows in set (0.00 sec) 24 25 ERROR: 26 No query specified 3 1 mysql...--------+------------------+------+-----+---------+----------------+ 9 3 rows in set (0.00 sec) 4 1 mysql...----------+------------------+------+-----+---------+----------------+ 9 3 rows in set (0.00 sec) 5 mysql
数据库也是一样,但显然要复杂许多,因为不仅面临着等值查询,还有范围查询(>、查询(like)、并集查询(or)等等。数据库应该选择怎么样的方式来应对所有的问题呢?...索引的类型 MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。 1.普通索引 在创建普通索引时,不附加任何限制条件。...查询记录时,就可以根据该索引进行查询。 2.唯一性索引 使用UNIQUE参数可以设置索引为唯一性索引。在创建唯一性索引时,限制该索引的值必须是唯一的。...在information字段上建立全文索引后,可以提高查询information字段的速度。MySQL数据库从3.23.23版开始支持全文索引,但只有MyISAM存储引擎支持全文检索。...唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `table_name
1.7 模糊查询 1.7.1 通配符 _ [下划线] 表示任意一个字符 % 表示任意字符 练习 1、满足“T_m”的有(A、C) A:Tom B:Toom C...:张牙舞爪 D:张 E:小张 4、满足“%诺基亚%”的是(ABCD) A:诺基亚2100 B:2100诺基亚 C:把我的诺基亚拿过来 D:诺基亚 1.7.2 模糊查询...(like) 模糊查询的条件不能用’=’,要使用like。...mysql> select * from stu where stuname like 'T_m'; +--------+---------+--------+--------+---------+--...mysql> select * from stu where stuname like '张%'; +--------+---------+--------+--------+---------+--
Mysql数据库-多表查询案例 我们在公司开发中,根据不同的业务需求往往需要通过2张及以上的表中去查询需要的数据。所以我们有必要学习2张及以上的表的查询。其实不管是几张表的查询,都是有规律可循的。...练习 2.1 练习1 查询所有员工信息。...不管我们查询几张表,表连接查询会产出笛卡尔积,我们需要消除笛卡尔积,拿到正确的数据。...(条件数量=表的数量-1),每张表都要参与进来 多表连接查询步骤:3.1. 确定要查询哪些表 3.2. 确定表连接条件 3.3. 确定查询字段 2.4 练习4 查询经理的信息。...(j.jname='经理') 确定查询字段:员工姓名,工资,职务名称,职务描述,部门名称,部门位置,工资等级 SELECT e.
领取专属 10元无门槛券
手把手带您无忧上云