最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

MySql数据查询的逻辑蕴含条件问题

来源:懂视网 责编:小采 时间:2020-11-09 08:29:35
文档

MySql数据查询的逻辑蕴含条件问题

MySql数据查询的逻辑蕴含条件问题:SQL语言中没有蕴含逻辑运算。但是,可以利用谓词演算将一个逻辑蕴含的谓词等价转换为:p-q ≡┐p∨q. 我们通过一个具体的题目来分析:(具体的表和数据详见文章: Mysql数据库中的EXISTS和NOT EXISTS ) 题目:查询至少选修了学生200215122选修的全
推荐度:
导读MySql数据查询的逻辑蕴含条件问题:SQL语言中没有蕴含逻辑运算。但是,可以利用谓词演算将一个逻辑蕴含的谓词等价转换为:p-q ≡┐p∨q. 我们通过一个具体的题目来分析:(具体的表和数据详见文章: Mysql数据库中的EXISTS和NOT EXISTS ) 题目:查询至少选修了学生200215122选修的全

SQL语言中没有蕴含逻辑运算。但是,可以利用谓词演算将一个逻辑蕴含的谓词等价转换为:p-q ≡┐p∨q. 我们通过一个具体的题目来分析:(具体的表和数据详见文章: Mysql数据库中的EXISTS和NOT EXISTS ) 题目:查询至少选修了学生200215122选修的全部课程的

SQL语言中没有蕴含逻辑运算。但是,可以利用谓词演算将一个逻辑蕴含的谓词等价转换为:p->q ≡┐p∨q.

我们通过一个具体的题目来分析:(具体的表和数据详见文章:Mysql数据库中的EXISTS和NOT EXISTS)

题目:查询至少选修了学生200215122选修的全部课程的学生号码。

本查询可以用逻辑蕴含来表达:查询学号为x的学生,对所有的课程y,只要200215122学生选修了课程y,则x也选修了y。

形式化表示如下:

用p表示谓词“学生200215122选修了课程y”;用q表示谓词“学生x选修了课程y”.

则上述查询为:(?y)p->q

该查询可以转换为如下等价形式:

(?y)p->q ≡ ┐(?y(┐(p->q)))≡ ┐(?y(┐(┐p∨q)))≡ ┐?y(p∧┐q)

它所表达的语义是这样的:不存在这样的课程y,学生200215122选修了y,而学生x没有选。

对应的SQL语句:

SELECT DISTINCT Sno
FROM SC SCX
WHERE NOT EXISTS 
(SELECT * FROM SC SCY WHERE SCY.Sno='200215122' AND NOT EXISTS 
	(SELECT * FROM SC SCZ WHERE SCZ.Sno=SCX.Sno AND SCZ.Cno=SCY.Cno)
);

首先对SCX中的第一条记录(200215121),SCY的第一条Sno='200215122'的记录进行判断,结果有数据返回,NOT EXISTS的值为假;

然后对SCY的下一条Sno='2002151221'的记录进行判断,直到遍历完所有的SCY的Sno='200215122',NOT EXISTS的值始终为假,则中间层的WHERE的值为假,最外层的NOT EXISTS的值为真,所以第一条数据符合查询条件,存放到结果表中;

然后对SCX中的下一条记录进行查询,直到遍历玩SCX表中所有数据。

结果输出:

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

MySql数据查询的逻辑蕴含条件问题

MySql数据查询的逻辑蕴含条件问题:SQL语言中没有蕴含逻辑运算。但是,可以利用谓词演算将一个逻辑蕴含的谓词等价转换为:p-q ≡┐p∨q. 我们通过一个具体的题目来分析:(具体的表和数据详见文章: Mysql数据库中的EXISTS和NOT EXISTS ) 题目:查询至少选修了学生200215122选修的全
推荐度:
标签: 查询 查看 数据
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top