酷站(www.ku0.com)-致力于为互联网从业者提供动力!

热门关键词:  企业  as  baidu  c4rp3nt3r  美女
酷站

【云小站】新老客都返现+现金红包+瓜分60万奖池
酷站

Mysql

旗下栏目: Mysql MsSql DB2 Redis mariadb Access oracle MongoDB PostgreSQL SQLite mssql2005 mssql2008

not exists的用法

来源:互联网搜集 作者:秩名 人气: 发布时间:2019-06-16
本篇文章主要介绍了not exists的用法,对大家的学习或者工作具有一定的参考学习价值,感兴趣的小伙伴们可以参考一下,也感谢大家对酷站(ku0.com)的支持。

本篇文章介绍not exists的用法。

not exists 是sql中的一个语法,常用在子查询和主查询之间,用于条件判断,根据一个条件返回一个布尔值,从而来确定下一步操作如何进行,not exists 也是exists或in的对立面。



not exists 是exists的对立面,所以要了解not exists的用法,我们首先了解下exists、in的区别和特点:

exists : 强调的是是否返回结果集,不要求知道返回什么, 比如:
 

select name from student where sex = 'm' and mark exists(select 1 from grade where ...)

只要exists引导的子句有结果集返回,那么exists这个条件就算成立了,大家注意返回的字段始终为1,如果改成“select 2 from grade where ...”,那么返回的字段就是2,这个数字没有意义。

所以exists子句不在乎返回什么,而是在乎是不是有结果集返回。
而 exists 与 in 最大的区别在于 in引导的子句只能返回一个字段,比如:

select name from student where sex = 'm' and mark in (select 1,2,3 from grade where ...)

in子句返回了三个字段,这是不正确的,exists子句是允许的,但in只允许有一个字段返回,在1,2,3中随便去了两个字段即可。

而not exists 和not in 分别是exists 和 in 的 对立面。

exists     (sql       返回结果集,为真)

主要看exists括号中的sql语句结果是否有结果,有结果:才会继续执行where条件;没结果:视为where条件不成立。
 

not exists   (sql       不返回结果集,为真)

主要看not exists括号中的sql语句是否有结果,无结果:才会继续执行where条件;有结果:视为where条件不成立。

not exists:经过测试,当子查询和主查询有关联条件时,相当于从主查询中去掉子查询的数据。

例如:

test数据:id name

1 张三

2 李四

select * from test c where  not exists

(select 1 from test t where t.id= '1' )

--无结果

select * from test c where  not exists

(select 1 from test t where t.id= '1'  and t.id = c.id)

--返回2 李四

 

版权声明:本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 959677720#qq.cn(#换@) 举报,一经查实,本站将立刻删除。

您可能感兴趣的文章:

原文链接:http://www.php.cn/jishu/mysql/417727.html

相关文章

  • mysql日志触发器的代码介绍

    mysql日志触发器的代码介绍

    sql语句: DROP TRIGGERIFEXISTS sys_menu_edit;CREATE TRIGGER sys_menu_edit BEFORE UPDATE ON sys_menu FOR EACH ROWBEGININSERT INTO `g4m`.`sys_log` ( `table_name`, `val_id`, `data_json` )VALUES(sys_menu,old.id,CONCAT({,CONC......
    02-02
  • 详解mysql将bin-log日志文件转为sql文件的方法

    详解mysql将bin-log日志文件转为sql文件的方法

    查看mysqlbinlog版本 mysqlbinlog -V [--version] 查看binlog日志开启状态 show variables like %log_bin%; mysql打开bin-log日志后,mysql数据库的非查询操作会将记录保存到bin-log文件中。一般bin-log日志文件不能打开查看的,需要用到......
    12-31
  • mysql累积聚合原理与用法解析

    mysql累积聚合原理与用法解析

    累积聚合为聚合从序列内第一个元素到当前元素的数据,如为每个员工返回每月开始到现在累积的订单数量和平均订单数量 行号问题有两个解决方案,分别是为使用子查询和使用连接。子查询的方法通常比较直观,可读性强。但是在要求进行聚合时......
    12-27
  • mysql日期处理函数教程

    mysql日期处理函数教程

    首先创建一张实验用的一张表 drop table if exists t_student; create table t_student( id int primary key auto_increment, name varchar(20) not null comment 姓名, birthday date comment 生日)Engine=InnoDB default charset utf8;......
    12-17
  • mysql触发器简介、创建触发器及使用限制的介绍

    mysql触发器简介、创建触发器及使用限制的介绍

    简介 SQL触发器是存储在数据库目录中的一组SQL语句。每当与表相关联的事件发生时,即会执行或触发SQL触发器,例如插入,更新或删除。SQL触发器也可以当做是一种特殊类型的存储过程。 它是特别的,因为它不像直接像存储过程那样调用。 触......
    12-16
  • mysql数据库中1045错误的解决教程

    mysql数据库中1045错误的解决教程

    本地数据库连接服务器数据库报1045,如何解决? 这个意思是说:用户root@本地主机的访问被拒绝 解决方案: 1.找到MySQL安装路径下的my.ini文件,用记事本的方式打开; 2.打开后,找到mysqld这个位置,这个文件的内容中有多个mysqld,注意......
    12-10
  • MySQL自增ID的一些小问题总结

    MySQL自增ID的一些小问题总结

    下面这几个小问题都是基于 InnoDB 存储引擎的。 1. ID最大的记录删除后,新插入的记录ID是什么 例如当前表中有ID为1,2,3三条记录,把3删除,新插入记录的ID从哪儿开始? 答案: 从4开始。 实验 创建表 tb0,ID自增: create table tb0(id......
    11-17
  • 安装mysql 8.0.17并配置远程访问的方法

    安装mysql 8.0.17并配置远程访问的方法

    一、安装前准备 查看数据库版本命令: mysql --version mysql-community-common-8.0.17-1.el7.x86_64.rpmmysql-community-libs-8.0.17-1.el7.x86_64.rpmmysql-community-client-8.0.17-1.el7.x86_64.rpmmysql-community-server-8.0.17-1.......
    10-17
  • mysql 5.7.25 压缩版安装配置方法图文的教程

    mysql 5.7.25 压缩版安装配置方法图文的教程

    第一步:下载 MySQL 5.7.25 压缩版 下载地址: 点击进入 第二步:安装 MySQL 5.7.25 压缩版 1、将压缩包解压到D盘,路径为:D:\mysql-5.7.25-winx64 2、在 D:\mysql-5.7.25-winx64 路径下新建一个 my.ini 文件,配置内容如下: [mysqld] ......
    10-17
  • 分享Mysql大型SQL文件快速恢复方案

    分享Mysql大型SQL文件快速恢复方案

    前言 在使用Mysql数据库的过程中,经常需要使用到备份和恢复数据库,最简单便捷的方法便是通过导出SQL数据文件和导入SQL数据文件来完成备份和恢复,但是随着项目的增长,数据量越来越大,每次恢复就成了一件很头疼的事情。 当我最近一次拉下项......
    09-11

最新更新