【数据库】关系元组演算——存在量词和全称量词

2023-10-17 06:20

本文主要是介绍【数据库】关系元组演算——存在量词和全称量词,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【数据库】关系元组演算——存在量词和全称量词

  • 学习数据库中遇到的小问题
    • 示例
    • 问题一:检索出课程都及格的所有同学(用全称量词表示)
    • 问题二:检索计算机系的所有同学(用存在量词表示)
    • 解释

学习数据库中遇到的小问题

对于 存在量词 与 全称量词 表示方式的差别


示例

三个表格分别为

学生关系:Student ( S#, Sname, Sage, Ssex, Sclass )
课程关系:Course ( C#, Cname, Chours, Credit, Tname )
选课关系:SC ( S#, C#, Score )

要求:
① 检索出课程都及格的所有同学
② 检索计算机系的所有同学


问题一:检索出课程都及格的所有同学(用全称量词表示)

两种书写方式

1.正确答案
正确答案
2.错误答案
在这里插入图片描述


问题二:检索计算机系的所有同学(用存在量词表示)

正确答案
正确答案


解释

全称量词的结束条件是遍历完全部或者遍历到第一个false

前一个遍历的范围就是 在学生集合的表里的某个学生所选课程 这一个集合,但是后一个是 全部学生所选课程的表 的集合,所以会出现一种情况,那就是第二个写法有可能出现遍历到不是这个指定 学生X 所选的课,此时结果为false,这时遍历就停止了,但是这时不一定遍历完所有该 学生X 所选的课,但是第一个写法遍历的对象永远只是 学生X 所选的课。

对于存在量词则不会有这种问题,因为存在量词结束的条件是遍历完全部或者遍历到第一个ture,为了编写SQL方便,对于存在量词还是建议写成第二种。

小技巧:现实中永远只会出现判断大范围的是不是包含小范围的,所以基本都是被包含着取全称量词,包含者是存在


学习于博主文章链接
https://blog.csdn.net/weixin_36309562/article/details/113270340?ops_request_misc=&request_id=&biz_id=102&utm_term=%E5%85%B3%E7%B3%BB%E5%85%83%E7%BB%84%E6%BC%94%E7%AE%97%E5%AD%98%E5%9C%A8%E9%87%8F%E8%AF%8D&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduweb~default-2-113270340.142v92chatsearchT3_1&spm=1018.2226.3001.4187

这篇关于【数据库】关系元组演算——存在量词和全称量词的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/223499

相关文章

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE