news 2026/4/23 17:53:01

数据库not exists 运算符

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据库not exists 运算符
写在前边

u1s1,这个符号真挺屎的吧,看起来简洁,但是给阅读带来很多障碍,要不是学校数据库课将这个,还考这个,真不想看这个。
这里的图片和例子都是来自b站up-四姨夫-的视频BV19K411x7hS中的,感谢,让我数据库也是混到了90。

exists
exists用于判断查询子句是否有记录 若有一条或多条记录存在,则返回true,否则返回false 只要找到一个符合条件的元组,则直接返回true,具有短路效果
not exists
用于判断查询子句是否有记录 若有一个或多个记录存在,则返回false,否则返回true 需要遍历全部的元组,若全不符合条件,才返回true,若有一个或多个符合条件,则返回true

一个经典的例子


数据库的查询语句的执行过程 1. 找到from后的表 2. 对表中的所有元组进行遍历,判断where是否成立,选中成立的元祖 3. 进行select
#查询选修了所有课程的学生对于上边这个两个notexists的语句notexists,不存在,所有都不满足条件,查询结构为空,返回true,否则返回selectSnamefromStudentwherenotexists(select*fromCoursewherenotexists(select*fromSCwhereSno=Student.SnoandCno=Course.Cno));这样一个三重嵌套查询,相当于三次for循环 最外层,遍历Student表中的所有元组 中间层,遍历Course表中的所有元组 最内层,遍历SC表中的所有元组 对与1Course SC表这个过程,11SC111,这个就满足条件,则内层的notexists返回false12SC121,不满足122,满足,内层的notexists返回false13SC131,不满足132,不满足133,满足,内层的notexists返回false三个都是false,则外层的notexists返回true若内层的notexists,其子查询为空,即一个都不满足,则返回true,(有一个学生有一门课没选) 对于外层,notexists,有一个true,则直接返回false,表示这个学生不符合要求
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:12:44

postgis数据库服务找不到

文章目录 问题描述 可能原因分析 排查步骤 解决方案 预防措施 高级故障排除 参考资料 手动启动 问题描述 PostGIS数据库服务找不到的常见表现和错误提示 可能原因分析 PostGIS扩展未正确安装或启用 数据库连接配置错误 PostgreSQL服务未正常运行 环境变量或路径设置问题 版本…

作者头像 李华
网站建设 2026/4/23 16:06:06

linux数据库备份shell及定时任务crontab时间格式

简单定时任务shell脚本内容:#!/bin/bash# MySQL数据库备份脚本# 基础配置信息db_user"root"db_password"04551Jhh"db_name"simple_shop"keep_days7backup_dir"/opt/backups"# 备份文件名为时间戳(修正了命令替换…

作者头像 李华
网站建设 2026/4/23 9:23:11

强烈安利8个AI论文平台,自考学生轻松搞定毕业论文!

强烈安利8个AI论文平台,自考学生轻松搞定毕业论文! AI 工具如何助力自考学生轻松完成论文 在自考学习过程中,毕业论文往往是许多学生最头疼的一环。面对繁重的写作任务和复杂的格式要求,很多学生感到无从下手,甚至因此…

作者头像 李华