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

mysql中select子查(select中的select子查询)询探索

它的执行过程如下: 1. 从emp表中查询员工编号为1的员工记录。 2. 对于查询结果中的每一条记录,都会执行一个子查询,查询该员工所在的部门名称。...在执行子查询的时候,子查询中的e.deptno是来自于主查询中的emp表,是通过where条件过滤出来的,所以子查询中的e.deptno是一个固定的值。...子查询的结果会作为一个临时表,与主查询中的emp表进行连接查询,最终得到员工姓名和部门名称的查询结果。...到这里对于select子查询的执行顺序更迷惑了,不知道DEPENDENT SUBQUERY到底时怎么执行的,到底有没有生产临时表,但是可以明确这种子查询的效率不如join好 注意事项 在select子查询中...,主查询只需要一行,例如查询部门名称,所在地,和部门中id最大的一个人的名称 mysql> select d.dname,(select e.ename from emp e where e.deptno

1.9K00

JAVA中SQL查询语句大全,select多表查询,各种查询

select * from emp; – 查询emp表中的所有员工的姓名、薪资、奖金 select name,sal,bonus from emp; – 查询emp表中的所有部门, 剔除重复的记录,...表中薪资为1400、1600、1800的员工,显示姓名和薪资 select name,sal from emp where sal in(1400,1600,1800); – 查询emp表中姓名中以”刘...多表连接查询 连接查询:将两张或者两张以上的表,按照指定条件查询,将结果显示在一张表中。 多张表查询的语法: select... from A, B... where......; 上面的查询(inner join…on…)方式也叫做内连接查询 外连接查询 1.左外连接查询 显示左侧表中的所有记录,如果在右侧表中没有对应的记录,则显示为null 语法: select ....右外连接查询 显示右侧表中的所有记录,如果在左侧表中没有对应的记录,则显示为null 语法: select ... from a right join b on(a.id=b.xid) – 查询部门和所有员工

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

    Oracle 中的SELECT 关键字(查询、检索)

    ) 如:select ename , sal*12 yearsal from emp; 方式二:列名后加空格再加“别名” (会直接以双引号里的格式显示,一般用于别名中包含空格等特殊符号的情况) 如:select...7.2创建计算字段的方式 方式一 :对某个列的数值进行计算(+-*/) Sql允许select子句(select后添加列名的位置)中出现由+,-,*,/以及列名和数字组成的表达式,将指定列中的值按照表达式进行计算...例:select sal*12 yearsal from emp; yearsal为别名 方式二:对几个列中的数据进行拼接,可以在列之间加入格式, 例:select (ename ||'的年薪为:'|...2000 union all select * from emp where deptno=20; 8.3 intersect(交集): 返回查询结果中相同的部分。...; 8.4 minus(差集): 返回在第一个查询结果中与第二个查询结果不相同的那部分记录。

    5.5K10

    select 高级查询之子查询

    当获得一个查询的答案需要多个步骤的操作,首先必须创建一个查询来确定用户不知道但包含在数据库中的值,将一个查询块嵌套在另一个查询块的 WHERE 字句或 HAVING 短语的条件中查询块称为子查询或内层查询...外部的 SELECT 查询语句,称为主查询或外查询。...后的子查询 1.3.1 查询每个部门员工个数 mysql> select dept.*, -> ( select count(*) from emp where emp.dept_id = dept.id...② 标量子查询,一般搭配着单行操作符使用,列子查询,一般搭配着多行操作符使用。  ③ 子查询的执行优先于主查询执行,因为主查询的条件用到了子查询的结果。  ...④ select 后面的子查询,仅仅支持标量子查询,即结果集只有一行一列。  ⑤ from 后面的子查询是将子查询的结果集充当一张临时表,要求必须起别名,否者这个表找不到。

    3.1K20

    select 进阶查询

    group_function:聚合函数 group_expression:group by 后的分组条件 group_condition:having 后的分组过滤条件 ☞ 注意  ① 分组查询中...③ having 后所接的字段必须经过过滤(即:该字段必须使用),一般与 group by 连用  ④ 分组查询中,若一个字段在一个组内有多个结果,则后一个结果覆盖前一个结果 1.1.2 聚合函数 函数名...说明 max( ) 查询指定列的最大值 min( ) 查询指定列的最小值 count( ) 统计查询结果的行数 sum( ) 求和,返回指定列的总和 avg( ) 求平均值,返回指定列数据的平均值...④ limit 为 MySQL 的 “方言” 在其他 SQL 中不一定能用。...400 的数据中 number 大于 3 的数据并按 name 分组,按照每组数据条数倒序,从 0 号数据开始查询 3 条数据 mysql> select *, count(*) from mydata

    1.5K51

    select基础查询

    查询表中所有学生的姓名和对应的英语成绩 过滤表中重复的数据 distinct 要查询的记录,每个字段都相同,才会去重 -- select 查询 select * from student; select...distinct name,chinese from student; -- 要查询的记录,每个字段都相同,才会去重 使用表达式进行运算,使用as语句 统计每个学生的总分 在所有学生总分加10分的情况...) > 200; -- 查询math>60 并且 english > 90 select * from student where `math`>60 and `english`>90; -- 查询总分大于...200并且math大于chinese的首字母为y的学生 select * from student where (chinese+math+english) > 200 and math>chinese...and `name` like 'y%'; -- 查询English在80到90分之间的 select * from student where english between 80 and 90;

    62020

    select 查询基础

    1.1 基础查询 1.1.1 查询所有列 ☞ 语法 # " * " 代表返回表中所有字段的数据 select * from tb_name; ☞ 示例 mysql> select * from student...1.1.2 查询指定字段 ☞ 语法 # tb_name 表中需要查询的字段 select field_1, field_2 from tb_name; ☞ 示例 mysql> select name,...1.2 条件查询 1.2.1 语法 # 条件查询 select * from 表名 where 条件; ☞ 注意   关键字 where 后面跟上一个或者多个条件,条件是对前面数据的过滤,只有满足 where...后面括号中可以包含多个值,对应记录的字段满足集合中任意一个都会被返回 NOT IN 不在集合中 严格比较两个 NULL 值是否相等 两个操作码均为 NULL 时,其所得值为 1;而当一个操作码为...③ LIKE 中的 % 可以匹配一个到多个任意的字符,_ 可以匹配任意一个字符,需要使用引号整体引起来。  ④ 既可以判断 NULL 值,又可以判断普通的数值,但可读性较低,不推荐使用。

    1K31

    【C 语言】指针间接赋值 ( 直接修改 和 间接修改 指针变量 的值 | 在函数中 间接修改 指针变量 的值 | 在函数中 间接修改 外部变量 的原理 )

    文章目录 一、直接修改 和 间接修改 指针变量 的值 二、在函数中 间接修改 指针变量 的值 三、在函数中 间接修改 外部变量 的原理 一、直接修改 和 间接修改 指针变量 的值 ---- 直接修改 指针变量...system("pause"); return 0; } 执行结果 : 二、在函数中 间接修改 指针变量 的值 ---- 在 函数 中 间接修改 指针变量 的值 , 将 指向一级指针.../* * 函数中简介修改指针值 */ void modify_pointer(int **p) { // 间接修改指针的值 *p = 456789; } int main()...p2 = &p; // 间接修改指针的值 *p2 = 12345678; // 打印一级指针地址 printf("%d\n", p); // 在函数中...三、在函数中 间接修改 外部变量 的原理 ---- 如果要 修改 一级指针 的值 , 必须 传入 指向 一级指针 的 二级指针 变量 才可以 , 传入一级指针变量 , 不能修改一级指针变量值 ; 这是因为

    24.3K11

    select 高级查询之连接查询

    1.1 笛卡尔积 1.1.1 概述   笛卡尔乘积是指在数学中,两个集合 X 和 Y 的笛卡尔积(Cartesian product),又称直积,表示为 X×Y,第一个对象是 X 的成员而第二个对象是...还可以被称为普通连接或者自然连接,内连接是从结果表中删除与其他被连接表中没有匹配行的所有行,所以内连接可能会丢失信息。... ② 第二种是先获取连接的结果,然后使用 where 中的条件再对连接结果进行过滤  ③ 内连接查询的数据不包含连接条件字段为 null 的数据 1.2.2 示例 mysql> select *...| +---------+-----------+--------+----------+ 3 rows in set (0.05 sec) 1.3 外连接   外连接涉及到 2 个表,主表和从表,要查询的信息主要来自于哪个表...外连接查询结果为主表中所有记录。如果从表中有和它匹配的,则显示匹配的值,这部分相当于内连接查询出来的结果;如果从表中没有和它匹配的,则显示null。

    1.3K10

    MyBatis-Select查询

    -- 场景一: 查询Employee的同时要查询员工对应的部门 Employee ===>Department 一个员工有与之对应的部门信息 --> <!...-- 使用association进行分步查询 1.先根据员工id查询员工信息 2.根据查询员工信息的中d_id值去查询部门信息 3.部门设置到员工中 --> 的封装规则 select: 表名当前属性是调用select指定的方法查出的结果 column:指定将那一列的传给这个方法 流程:使用select...-- 可以使用 延迟加载 Employee ==> Dept 每次查询Employee对象的时候,都将一起查询出来 部门信息在我们使用的时候再去查询; 分段查询的基础之上加上两个配置...-- 场景二: 查询部门的时候将部门对应的所有员工信息也查询出来 --> <!

    65930

    SQL 基础-->SELECT 查询

    --================================ --SQL 基础-->SELECT 查询 --================================= /* 一、SQL...结构化查询语言 包括DDL(数据定义语言)、DCL(数据控制语言)、 DQL(数据查询语言)、DML(数据操纵语言) 二、SQL的特点 SQL 语句不区分大小写 SQL 语句能输入一行或多行...关键字不能整行缩写或分离 子句通常被放置在分开的行上 缩进可提高可读性 在SQL 开发工具,SQL 语句能选择分号结束(;) .当你运行多个SQL 语句的时候,需要分号 在SQL*Plus中,...你要用一个分号结束每个SQL 语句.(;) 三、SQL*PLUS特征: 字符日期左对齐 数字右对对齐 列名默认大写 SQL PLUS 自己的命令不需以分号“;”结束 四、SQL查询时,数字和日期类型的数据可用算术运算符...六、SELECT语句的用法 SELECT *|{[DISTINCT] column|expression [alias],...}

    1.4K20

    select 进阶查询语句

    普通的 select…from 很明显不能满足我们的更细化的查询需求,它除了基本语法外,还可以拓展使用一些判断语法和过滤、分组语法。本文介绍一些 select 的进阶查询语法。...1; 子查询 子查询其实就是嵌套 select 语句查询,嵌套的 select 要用小括号括起来,子查询可以写在 select 后面,也可以写在 from 后面,也可以写在 where 后面,但是写在不同的位置都有不同的规则...SALES和ACCOUNTING的员工信息,其中 in 语法表示等于条件中的任意一个都成立 select * from emp where deptno in ( select...30号部门任意一个员工公司高的员工,其中 any 语法表示和集合中的任意一个值比较符合条件就可以 select * from emp where sal > any ( select...emp order by sal desc ) where rownum <= 3 2、查找员工表中薪水大于本部平均薪水的员工 方法1: select empno,

    72420

    SELECT 语句中的 子查询(Sub Query)

    SELECT 语句中的子查询 子查询(Sub Query)或者说内查询(Inner Query),也可以称作嵌套查询(Nested Query),是一种嵌套在其他 SQL 查询的 WHERE 子句中的查询...使用子查询必须遵循以下几个规则: 子查询必须括在圆括号中。 子查询的 SELECT 子句中只能有一个列,除非主查询中有多个列,用于与子查询选中的列相比较。...子查询不能使用 ORDER BY,不过主查询可以。在子查询中,GROUP BY 可以起到同 ORDER BY 相同的作用。 返回多行数据的子查询只能同多值操作符一起使用,比如 IN 操作符。...SELECT 列表中不能包含任何对 BLOB、ARRAY、CLOB 或者 NCLOB 类型值的引用。 子查询不能直接用在集合函数中。...INSERT 语句可以将子查询返回的数据插入到其他表中。子查询中选取的数据可以被任何字符、日期或者数值函数所修饰。

    4.3K20

    分组查询时,select的字段是否一定要都在group by中?

    一般情况下,我们在使用group by的时候,select中的列都要出现在group by中,比如select id,name,age from tuser group by id,name,age,那么我们是不是都要严格按照这种模式来写...大致的意思是:如果name列是主键或者是唯一的非空列,name上面的查询是有效的。这种情况下,MySQL能够识别出select中的列依赖于group by中的列。...比如说,如果name是主键,它的值就决定了address的值,因为每个组只有一个主键值,分组中的每一行都具有唯一性,因此也不需要拒绝这个查询。 4....,也可以不用在group by中把select中的字段全部列出来。...ONLY_FULL_GROUP_BY 我们在上面提到select中的列都出现在group by中,其实在MySQL5.7.5之前是没有此类限制的,5.7.5版本在sql_mode中增加了ONLY_FULL_GROUP_BY

    7.4K20

    sql数据库嵌套查询_select嵌套查询

    嵌套查询是将一个select 查询放到另一个查询的where 子句中去 如:查询”xx“同学的所修课程及分数 1.先选择姓名为”xx”的同学的学号 select 学号 from 学生 where 姓名...学号 from 学生 where 姓名=”xx”); 带有in的子查询 查询与”xxx”在同一个系学习的学生的学生姓名及其院系名称 分步骤: 1.先查询 xxx 所在的系 select 院系编号 from...学生 where 姓名=”xxx”; 假如结果为:”yyy”; 2.查询 “yyy”的名称及该系学习的学生 select 姓名,院系名称 from 学生,院系 where 所属院系 = 院系编号 and...”xx”的学生学号和姓名 1,先从课程表中查询课程名为”xx”的课程编号 as: select 课程编号 from 课程表 where 课程名=”xx” 2.从成绩表中查询学生学号,通过1中的课程编号...as: select 学生学号 from 成绩 where 课程编号 in(1) 3.从学生表中查询学生学号,姓名通过2中的学号 最后合并为 select 学生学号,姓名 from 学生表 where

    5.1K30
    领券