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

mysql】多表查询分类

多表查询分类 分类1:等值连接 vs 非等值连接 1....阿里开发规范: 【强制】对于数据库中表记录的查询和变更,只要涉及多个表,都需要在列名前加表的别名(或 表名)进行限定。...(或表名)的限制,正常运行两年后,最近在 某个表中增加一个同名字段,在预发布环境做数据库变更后,线上查询语句出现出 1052 异常:Column 'name' in field list is ambiguous...`employee_id`; [在这里插入图片描述] 分类3:内连接 vs 外连接 除了查询满足条件的记录以外,外连接还可以查询某一方不满足条件的记录。...外连接的分类:左外连接、右外连接、满外连接 左外连接:两个表在连接过程中除了返回满足连接条件的行以外还返回左表中不满足条件的行,这种连接称为左外连接。

2.3K40

MYSQL数据库-复合查询

MYSQL数据库-复合查询 零、前言 一、基本查询 二、多表查询 三、自连接 四、子查询 1、单行子查询 2、多行子查询 3、多列子查询 3、在from子句中使用子查询 五、合并查询 1、union 2...、union all 零、前言 本章主要讲解学习MYSQL数据库中的复合查询,前面我们讲解的mysql表的查询都是对一张表进行查询,在实际开发中这远远不够 一、基本查询 示例: 查询工资高于500...worker,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别 四、子查询查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 1、单行子查询 返回一行记录的子查询...,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句 示例:查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人 3、在from...子句中使用子查询查询语句出现在from子句中。

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

MySQL数据库查询

SQL语句,子查询被嵌入到一对小括号里面 数据库设计之三范式 1、数据库设计之三范式的介绍 范式: 对设计数据库提出的一些规范,目前有迹可寻的共有8种范式,一般遵守3范式即可。...5、E - R模型的介绍 E-R模型即实体-关系模型,E-R模型就是描述数据库存储数据的结构模型。...E-R模型由 实体、属性、实体之间的关系构成,主要用来描述数据库中表结构。...goods values(0,'商务双肩背包','笔记本配件','索尼','99',default,default); 表结构说明: id 表示主键 自增 name 表示商品名称 cate_name 表示分类名称...、价格 select name,price from goods where cate_name = ‘超级本’; 2、显示商品的分类 select cate_name from goods group

18.5K20

数据库MySQL查询优化

MySQL发送查询请求,到底做了什么工作? 下图是MySQL查询执行流程图: ? •客户端发送一条查询给服务器。•服务器先检查查询缓存,如果命中了缓存,则立刻返回查询在缓存中的结果。...•MySQL根据优化器生成的执行计划,调用存储引擎的API来执行查询。•将结果返回给客户端。 是什么导致MySQL查询变慢了?...对于MySQL,最简单的衡量查询开销的三个指标如下: •响应时间•扫描的行数•返回的行数 没有哪个指标能够完美地衡量查询的开销,但它们大致反映了MySQL在内部执行查询时需要访问多少数据,并可以大概推算出查询运行的时间...2.关联子查询 MySQL的子查询实现是非常糟糕的。...列表中的选项有专门的优化策略,一般会认为MySQL会先执行子查询返回所有包含author_id 为1的book_id。

13.4K10

Mysql数据库-子查询

Mysql数据库-子查询 1. 什么是子查询 # 子查询定义 ## B语句作为A语句的一部分,B语句是select查询语句,那么B语句称之为子查询,内层查询(子集,subquery) -- 1....查询emp表的最高工资salary,然后再根据最高工资salary查询员工的信息 -- 2.1 通过max(salary)可以查询出emp表的最高工资为9000 mysql> select max(salary...子查询分类 在上面的执行示例中,我们已经了解到了什么是子查询。那么子查询可以按照查询返回的不同结果,进行一些简单的分类,如下: #按结果集的行列数不同 1....查询工资大于5000的员工,来自于哪些部门的名字 -- 1.1 首先查询salary>5000的部门ID,列子查询(多行单列) mysql> select dept_id from emp where...第三次执行 : 同理 select dept.*,( -- 我们可以发现这个子查询是无法单独执行的..因为这是子查询分类中的 【相关子查询:子查询的执行是依赖外部的查询,外部执行一行,子查询则会执行一次

45.5K10

MySQL数据库——连接查询

概述: 连接查询的作用将多张表进行内容上的连接,查看数据时可以同时看到多张表的多个数据 连接查询分类 内连接查询 左连接查询 右连接查询 自连接查询 语法 #内连接 SELECT * FROM...b_table b on a.a_id = b.b_id; #自连接 SELECT * FROM a_table a inner join a_table a on a.a_id = a.b_id; 分类...内连接查询 inner join 实现多表查询查询共有记录。...SELECT * FROM 表1 inner join 表2 on 表1.字段=表2.字段 左连接查询 left join 以左表为主,查询右表的数据。若右表不存在数据,则返回null。...SELECT * FROM 表1 right join 表2 on 表1.字段=表2.字段 自连接查询 inner join 左表和右表是同一个表,查询两个表中的数据。

53.8K85

MySQL数据库,详解索引分类

索引分类 分为聚集索引和⾮聚集索引。...聚集索引 每个表有且⼀定会有⼀个聚集索引,整个表的数据存储在聚集索引中,mysql索引是采⽤B+树结构保存在⽂件中,叶⼦节点存储主键的值以及对应记录的数据,⾮叶⼦节点不存 储记录的数据,只存储主键的值。...当表中未指定主键时,mysql内部会⾃动给每条记录添加⼀个隐藏的rowid字段(默认4个字节)作为主键,⽤rowid构建聚集索引。 聚集索引在mysql中又叫主键索引。...mysql中⾮聚集索引分为 单列索引 即⼀个索引只包含⼀个列。 多列索引(⼜称复合索引) 即⼀个索引包含多个列。 唯⼀索引 索引列的值必须唯⼀,允许有⼀个空值。...innodb我们⽤的最多,我们只看图中左边的innodb中数据检索过程: 如果需要查询id=14的数据,只需要在左边的主键索引中检索就可以了。

1.2K10

mysql数据库查询数据的语句怎么写_mysql数据库多表查询

单表查询 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岁学生的不及格成绩 我们利用左外连接查询,先将学生表中所有年龄小于

29.8K20

MySQL数据库】详细讲解MySQL查询

图片多表查询⭐多表关系在项目开发中,在进行数据库表结构设计时,会根据业务需求以及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在各种联系,基本分为以下三种一对多(多对一...varchar(10) comment '课程名称') comment '课程表';​insert into course values (null,'java'),(null,'php'),(null,'mysql...原来的表 图片联合查询对于联合查询(union),就是把多次查询的结果合并起来,形成一个新的查询结果集查询到的多张表的列数要保持一致,而且字段列表也要保持一致select 字段列表 from 表A……...;子查询的外部语句可以是insert update delete selete的任何一个️‍根据查询结果不同,分为查询方式查询结果标量子查询查询结果为单个值列子查询查询结果为一列行子查询查询结果为一行表子查询查询结果为多行多列...,或者文章有问题,欢迎大家在评论区讨论,指正我正在参与 腾讯云开发者社区数据库专题有奖征文。

25140

MySQL 模糊查询MySQL 数据库 like 语句通配符模糊查询小结

MySQL 报错:Parameter index out of range (1 > number of parameters, which is 0)——MySQL 数据库 like 语句通配符模糊查询小结...文章目录 MySQL 报错:Parameter index out of range (1 > number of parameters, which is 0)——MySQL 数据库 like 语句通配符模糊查询小结...前言 一、分析 SQL 语句 1.1、普通 SQL 语句的查询分析 1.2、普通 SQL 查询语句如何处理 1.3、使用 like 通配符模糊查询语句分析 二、like 语句使用通配符模糊查询剖析 2.1...、like 语句的应用场景 2.2、模糊查询剖析 2.3、正确语句 三、MyBatis like 模糊查询及关键字区分 总结 ---- 前言 今天在使用 MySQL 语句执行增删改查操作时,控制台报出了以下错误...二、like 语句使用通配符模糊查询剖析 2.1、like 语句的应用场景 使用 like 通配符进行模糊查询是我们在项目中常遇到的,比如在搜索框中对于数据的模糊查询

14.8K40

MySQL数据库——多表查询之内连接查询、外连接查询、子查询

1 多表查询 1.1 多表查询概述 多表查询就是从多个表中进行数据的查询操作,语法:select  列名列表 from 表名的列表  where......】:SELECT *FROM dept,emp; 从查询结果中可以看到共计15条数据,这个查询结果叫做笛卡尔积,如查询2个表,每个表中的数据条数分别为A,B,则查询的结果条数就是A*B;但是看如下结果,...1.2 多表查询分类 1.2.1 内连接查询 1)隐式内连接:使用where条件来消除无用的数据; -- 查询所有员工信息和对应的部门信息 SELECT *FROM emp,dept WHERE emp...`id`; 3)内连接查询注意事项: 从哪些表中查询; 条件是什么; 查询哪些字段; 1.2.2 外连接查询 1)左外连接:查询的是左表所有的数据及其交集部分。...语法:select 字段列表 from 表1 right [outer] join 表2 on 条件 1.2.3 子查询 【概念】:子查询就是查询中嵌套查询,称嵌套查询为子查询

11.7K10

数据库MySQL-子查询

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

3.5K20
领券