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

SQL中EXISTS的使用

普通SQL查询: SELECT 姓名 FROM 学生表 WHERE 学号 IN (SELECT 学号 FROM 选课表 WHERE 课程号 = 'C1'); 带EXISTS的SQL查询: SELECT...); 相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,用该记录的相关的属性值(在内层WHERE子句中给定的)处理内层查询,若外层的WHERE子句返回“TRUE”值,则这条记录放入结果表中。...然后再取下一行记录;重复上述过程直到外层表的记录全部遍历一次为止。 EXISTS语句不关心子查询的具体内容,因此用“SELECT *”,“Exists + 子查询”用来判断该子查询是否返回记录。...4.查询没有选C1课程的学生的学号、姓名 SELECT 姓名 FROM 学生表 WHERE NOT EXISTS ( SELECT * FROM 选课表 WHERE 学生表.学号...= 选课表.学号 AND 课程号 = 'C1' ); 5.查询选修了所有课程的学生的姓名(续) SELECT 姓名 FROM 学生表 WHERE NOT EXISTS ( SELECT *

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

    SQL 中的in与not in、exists与not exists的区别以及性能分析

    end if  end loop  对于in 和 exists的性能区别 ---- 如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in,反之如果外层的主查询记录较少,子查询中的表大...对于not in 和 not exists的性能区别: not in 只有当子查询中,select 关键字后的字段有not null约束或者有这种暗示时用not in,另外如果主查询中表大,子查询中的表小但是记录多...如果主查询表中记录少,子查询表中记录多,并有索引,可以使用not exists,另外not in最好也可以用/*+ HASH_AJ */或者外连接+is null NOT IN 在基于成本的应用中较好...from title T, rollup R  where R.source_id = T.Title_id(+)  and T.Title_id is null;  或者 sql> select /*... t2 ) t2  where t1.x = t2.y;  ——如果你有一定的SQL优化经验,从这句很自然的可以想到t2绝对不能是个大表,因为需要对t2进行全表的“唯一排序”,如果t2很大这个排序的性能是

    2.1K00

    SQL中的in与not in、exists与not exists的区别以及性能分析

    end if end loop 对于in 和 exists的性能区别: 如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in,反之如果外层的主查询记录较少,子查询中的表大,又有索引时使用...所以要具体需求来决定 对于not in 和 not exists的性能区别: not in 只有当子查询中,select 关键字后的字段有not null约束或者有这种暗示时用not in,另外如果主查询中表大...如果主查询表中记录少,子查询表中记录多,并有索引,可以使用not exists,另外not in最好也可以用/*+ HASH_AJ */或者外连接+is null NOT IN 在基于成本的应用中较好...from title T, rollup R where R.source_id = T.Title_id(+) and T.Title_id is null; 或者(佳) sql> select...t2 ) t2 where t1.x = t2.y; ——如果你有一定的SQL优化经验,从这句很自然的可以想到t2绝对不能是个大表,因为需要对t2进行全表的“唯一排序”,如果t2很大这个排序的性能是

    4.1K20

    SQL中的in与not in、exists与not exists的区别以及性能分析

    end if end loop 对于in 和 exists的性能区别: 如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in,反之如果外层的主查询记录较少,子查询中的表大,又有索引时使用...所以要具体需求来决定 对于not in 和 not exists的性能区别: not in 只有当子查询中,select 关键字后的字段有not null约束或者有这种暗示时用not in,另外如果主查询中表大...如果主查询表中记录少,子查询表中记录多,并有索引,可以使用not exists,另外not in最好也可以用/*+ HASH_AJ */或者外连接+is null NOT IN 在基于成本的应用中较好...from title T, rollup R where R.source_id = T.Title_id(+) and T.Title_id is null; 或者(佳) sql> select...t2 ) t2 where t1.x = t2.y; ——如果你有一定的SQL优化经验,从这句很自然的可以想到t2绝对不能是个大表,因为需要对t2进行全表的“唯一排序”,如果t2很大这个排序的性能是

    2.5K20

    SQL中的in与not in、exists与not exists的区别以及性能分析

    end if end loop 对于in 和 exists的性能区别: 如果子查询得出的结果集记录较少,主查询中的表较大且又有索引时应该用in,反之如果外层的主查询记录较少,子查询中的表大,又有索引时使用...所以要具体需求来决定 对于not in 和 not exists的性能区别: not in 只有当子查询中,select 关键字后的字段有not null约束或者有这种暗示时用not in,另外如果主查询中表大...如果主查询表中记录少,子查询表中记录多,并有索引,可以使用not exists,另外not in最好也可以用/*+ HASH_AJ */或者外连接+is null NOT IN 在基于成本的应用中较好...from title T, rollup R where R.source_id = T.Title_id(+) and T.Title_id is null; 或者(佳) sql> select...t2 ) t2 where t1.x = t2.y; ——如果你有一定的SQL优化经验,从这句很自然的可以想到t2绝对不能是个大表,因为需要对t2进行全表的“唯一排序”,如果t2很大这个排序的性能是

    61530

    MySQL对CREATE TABLE IF NOT EXISTS SELECT的处理

    1.MySQL对CREATE TABLE IF NOT EXISTS SELECT的处理 MySQL支持创建持数据表时判断是否存在,存在则不创建,不存在则创建,相应语句如下: --格式 CREATE...null primary key,name varchar(32) not null); MySQL官方对CREATE TABLE IF NOT EXISTS SELECT给出的解释是: CREATE...当数据表存在的时候,使用insert into select将select的结果插入到数据表中,当select的结果集的列数与数据表的列数不相匹配时,又分为两种情况: 第一种:select的结果列数m小于原数据表的列数...If strict SQL mode is enabled and any of these initial columns do not have an explicit default value,...一个解决的办法就是先drop table,再执行CREATE TABLE IF NOT EXISTS SELECT。

    3.6K30

    sql中select into的用法_sql语句insert into用法

    大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说sql中select into的用法_sql语句insert into用法,希望能够帮助大家进步!!!...1.select into from语句: 注意内容:要求目标表A不存在,因为在插入时会自动创建表A,并将B中指定字段数据复制到A中。...B的主键约束,如果B有主键而且不为空,则 field1, field2...中必须包括主键 (3)注意语法,不要加values,和插入一条数据的sql混了,不要写成:insert into B (field...,field2) values (1,2) 正确写法SQL: 此代码由Java架构师必看网-架构君整理 insert into B (field,field1,...) select value,value1...,... from A 或 insert into B select * from A 今天文章到此就结束了,感谢您的阅读,Java架构师必看祝您升职加薪,年年好运。

    2.2K30

    数据库 SQL中IN和EXISTS用法的区别

    (为一个完整的语句)返回的数据是否为null,如果不为null,就会将当前的数据加入结果集,因此我们select * from a的时候,我们是从第一条数据开始执行的,每次执行都会去执行exists的子查询...* from A where id in(select id from B) 以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B表中的id相等...结论:in()适合B表比A表数据小的情况 ---- select a.* from A a where exists(select 1 from B b where a.id=b.id) 以上查询使用了...它的查询过程类似于以下过程 List resultSet=[]; Array A=(select * from A) for(int i=0;i<A.length;i++) { if(exists...如:A表有10000条记录,B表有1000000条记录,那么exists()会执行10000次去判断A表中的id是否与B表中的id相等.

    1.2K30

    Oracle中的SQL优化

    推荐方案:用NOT EXISTS 或(外连接+判断为空)方案代替 3. 操作符(不等于)     不等于操作符是永远不会用到索引的,因此对它的处理只会产生全表扫描。    ...实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。...同一功能同一性能不同写法SQL的影响(使用ORACLE的共享SQL程序)     如一个SQL在A程序员写的为:Select * from zl_yhjbqk     B程序员写的为:Select *...以下' and xh_bz=1     Select * from zl_yhjbqk where xh_bz=1 and dy_dj = '1KV以下'     以上两个SQL中dy_dj(电压等级)...b.查询表顺序的影响     在FROM后面的表中的列表顺序会对SQL执行性能影响,在没有索引及ORACLE没有对表进行统计分析的情况下ORACLE会按表出现的顺序进行链接,由此因为表的顺序不对会产生十分耗服务器资源的数据交叉

    1.9K20

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

    ) 如:select ename , sal*12 yearsal from emp; 方式二:列名后加空格再加“别名” (会直接以双引号里的格式显示,一般用于别名中包含空格等特殊符号的情况) 如:select...,数值不用加单引号 5. exists(sub-query)、not exists(sub-query) 子查询 sub-query:子查询 exists(sub-query):满足该条记录的子查询时(...有查找到)执行该条记录父查询 not exists(sub-query):不满足该条记录的子查询时执行父查询 如:select * from emp where exists(select *from...7.2创建计算字段的方式 方式一 :对某个列的数值进行计算(+-*/) Sql允许select子句(select后添加列名的位置)中出现由+,-,*,/以及列名和数字组成的表达式,将指定列中的值按照表达式进行计算...例:select sal*12 yearsal from emp; yearsal为别名 方式二:对几个列中的数据进行拼接,可以在列之间加入格式, 例:select (ename ||'的年薪为:'|

    4.1K10

    oracle基础|oracle的认知|Select用法详解

    可以通过使用结构化查询语句(Structured Query Language (SQL))来操作元组数据 3.属性:元组中的一个属性值(分量) 4.码:如果在一个关系中存在这样的一个属性,它的值能够用来唯一标识一行...1998年9月,ORACLE公司正式发布ORACLE 8i。“i”代表Internet,这一版本中添加了大量为支持Internet而设计的特性。这一版本为数据库用户提供了全方位的Java支持。...3.三个名词: sql:结构化的查询语句,操作oracle数据库的语言 sqlplus:oracle软件自带的可以输入sql,且将sql执行结果显示的终端 pl/sql:程序化的slq语句,在sql语句的基础上加入一定的逻辑操作...\summit2.sql start e:/oracle/summit2.sql 6.查看表结构: desc table_name; ---- select用法详解 1.select : 语法:...(对于windows使用的是notepad) spool file_name 将接下来的sql语句以及sql的运行结果保存到文件中(append) sql1 result1 sql2 result2

    2.5K20

    Oracle中的基本SQL知识

    什么是SQL语言 a) SQL, Structured Query Language, 结构化查询语言 b) SQL 是最重要的关系数据库操作语言,是所有关系数据库 管理系统的标准语言....开始设置使用Oracle时的相关准备 设置字体 ? 关闭自动备份,避免生成同名文件 ? select基本语句 一般使用的是Oracle自带的scott用户,密码默认为tiger,不过要手动创建一下。...d) 在 Oracle 中, 双引号表示原样输出. select ename, job, sal*12 "ni a n xin" from emp; 5、 distinct 用于去除重复行信息 a)...select distinct ename, job from emp; 6、字符串连接符 Oracle 中, 用单引号表示字符串 a) 查询所有员工的姓名, 职位和薪资, 以姓名:xxx, 职位...emp where ename like '_A%'; c) 查询姓名中带有字母 C 的员工的信息 select * from emp where ename like '%C%'; d) 查询姓名中带有下划线的员工的信息

    1.1K20

    SQL中SELECT语句详解「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 本篇文章讲述SQL语句中的SELECT查询语句,以供参考,如有错误或不当之处还望大神们告知。...简单查询SELECT-FROM 用于无条件查询单张表中的行或列 假设有表如图所示 查询名字叫 ‘叶清逸’ 的记录: select * from T_USER where u_name = '叶清逸...“||” SQL中的连接符”||” 可将结果连接起来为一列 – 将u_name 和“的成绩为” u_score 连接起来 select u_name || '的成绩为' || u_score as...成绩 from T_USER ; 查询结果: 条件查询SELECT-WHERE SQL中可以用SELECT-WHERE进行条件查询 比较运算 ‘’ ‘>=’ ‘!...=’ SQL中可以使用 条件运算符 ‘’ ‘>=’ ‘!=’ 过滤查询结果中的某些行,多个条件之间可以用 ‘and’ 连接。

    2.3K10

    「基础」SQL-Hive中的select from 解析

    今天我们来讲讲Hive中最常用的 select from 语句知识要点。 Hive系列文章预计10-20篇,主要讲数据分析中最基础的SQL技能。每周定期更新,欢迎关注公众号。...01-查询表中的内容 查询指定的某一列或某几列,命令如下: SELECT 列名1,列名2,…… FROM 表名; 查询表中的所有字段时,可以使用*代表所有字段。星号(*)是选取所有列的快捷方式。...命令如下: SELECT * FROM 表名; 如果我们想查询表 t_od_use_cnt 中的所有的user_id和use_cnt,具体命令如下: SELECT user_id ,use_cnt...比如这里我们的分区字段是date_8这个日期字段,工作中的表会要求我们必须限定查询哪几天的分区数据。...通常有必要给这些新产生的列起一个别名。已有列的列名如果含义不清晰也可以通过起别名的方式进行更改。不过别名只在本条SQL语句中生效,不影响原表中的字段名。

    1.6K40

    SqlServer中Exists的使用

    ='C1') 相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,利用该记录的相关属性值(在exists子查询的where子句中用到的列)处理内层查询,若外层的where子句返回“true”,则本条记录放入结果表中...Exists语句不关心子查询返回的具体内容,因此用“exists(select 1 from)”来判断子查询是否返回记录。...Exists(select):若子查询的结果集非空时,exists()表达式返回true;子查询的结果集为空时,exists()表达式返回false。...Not Exists(select):若子查询的结果集非空时,not exists()表达式返回false;子查询的结果集为空时,not exists()表达式返回true。...exists()值为true,说明选课表中找不到“S1.StudentNo + C1.CourseNo”这一记录,说明学生S1没有选课程C1,此时内层查询的返回结果集会加上C1,当内层查询的返回结果集不为空时

    63710
    领券