SQL select查询原理--查询语句执行原则转

1.单表查询:根据WHERE条件过滤表中的记录,形成中间表(这个中间表对用户是不可见的);然后根据SELECT的选择列选择相应的列进行返回最终结果。


1)简单的单表查询

SELECT 字段 
FROM 表名 
WHERE 条件表达式

那它们是按什么顺序执行呢?分析器会先看语句的第一个词,当它发现第一个词是SELECT关键字的时候,它会跳到FROM关键字,然后通过FROM关键字找到表名并把表装入内存。接着是找WHERE关键字,如果找不到则返回到SELECT找字段解析,如果找到WHERE,则分析其中的条件,完成后再回到SELECT分析字段。最后形成一张我们要的虚表。
WHERE关键字后面的是条件表达式。如果学过C语言等编程语言就会知道,条件表达式计算完成后,会有一个返回值,即非0或0,非0即为真(true),0即为假(false)。同理WHERE后面的条件也有一个返回值,真或假,来确定接下来执不执行SELECT。

例: 
SELECT * 
FROM STUDENT 
WHERE SNO = '1';

分析器先找到关键字SELECT,然后跳到FROM关键字将STUDENT表导入内存,并通过指针p1找到第一条记录,接着找到WHERE关键字计算它的条件表达式,如果为真那么把这条记录装到一个虚表当中,p1再指向下一条记录。如果为假那么p1直接指向下一条记录,而不进行其它操作。一直检索完整个表,并把虚表返回给用户。

再说EXISTS谓词,EXISTS谓词也是条件表达式的一部分。当然它也有一个返回值(true或false)。

例: 
SELECT Sname 
FROM Student 
WHERE EXISTS 
(SELECT * 
FROM SC 
WHERE SC.Sno = Student.Sno AND SC.Cno = '1');

这是一个SQL语句的嵌套使用,但和上面说的SQL语句的执行过程也是相同的。嵌套的意思也就是说当分析主SQL语句(外面的那个SELECT)到WHERE关键字的时候,又进入了另一个SQL语句中。那么也就是说,分析器先找到表Student并装入内存,一个指针(例如p1)指向Student表中的第一条记录。然后进入WHERE里分析里面的SQL语句,再把SC表装入内存,另一个指针(例如p2)指向SC表中的第一条记录,分析WHERE后面的条件表达式,依次进行分析,最后分析出一个虚表2,也就变成

SELECT Sname 
FROM Student 
WHERE EXISTS 虚表2

如果虚表为空表,EXISTS 虚表2 也就为false,不返回到SELECT,而p1指向下一条记录。如果虚表2不为空也就是有记录,那么EXISTS 虚表2 为true同,返回到SELECT并把p1指向的记录添加到主SQL语句的虚表1当中。(这也是为什么嵌套的SQL语句SELECT 后面为一般为*的原因,因为它EXISTS返回的只是真或假,字段的名没有意义,用*就行,当然用别的也不会错。 )

注意,这里虽然嵌套的SQL语句分析完了,但主SQL语句只执行了一遍,也就是说p1指向Student的第一条记录,p1还要再指向Student表的下一条记录并分析,这样又进入了嵌套中的SQL语句,同上面说的一样分析。当p1也到了Student表的结尾,整个SQL语句结束。返回虚表1Sname这一列。

嵌套就像:

for(int i = 0,i < n, ++i) 
for(int j = 0, j < n, ++j)

2,两表连接查询:对两表求积(笛卡尔积)并用ON条件和连接连接类型进行过滤形成中间表;然后根据WHERE条件过滤中间表的记录,并根据SELECT指定的列返回查询结果。

3.多表连接查询:先对第一个和第二个表按照两表连接做查询,然后用查询结果和第三个表做连接查询,以此类推,直到所有的表都连接上为止,最终形成一个中间的结果表,然后根据WHERE条件过滤中间表的记录,并根据SELECT指定的列返回查询结果.

4.不同类型的连接查询什么时候用

查两表关联列相等的数据用内连接。
左表的连接列是右表的子集时用右外连接。
右表的连接列是左表的子集时用左外连接。
左表的连接列和右表的连接列彼此有交集但彼此互不为子集时候用全外。
求差操作的时候用联合查询。
多个表查询的时候,这些不同的连接类型可以写到一块。
ON只进行连接操作,WHERE只过滤中间表的记录

转自http://blog.csdn.net/chenjian198819/article/details/6794316

转载于:https://www.cnblogs.com/winkey4986/p/4136033.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257926.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android导航二级分类,Android实现腾讯新闻的新闻类别导航效果

效果图如下所示&#xff1a;1、在Adapter中加入如下代码private int clickTemp -1;//TODO 被选择的item下标/** * TODO 传入下标&#xff0c;设置被选择的item * * param position */public void setSelection(int position) {clickTemp position;}2、在Adapter的getView方法…

Linux下访问window挂载的磁盘

点击window挂在的磁盘,如下图左侧"文档". 出现如下错误: Error mounting /dev/sda3 .... Command-line mount -t "ntfs" -o "uhelperudisks2 修复办法: sudo ntfsfix /dev/sda6 参考资料: 1. win8安装ubuntu后不能访问windows其他磁盘转载于:https:…

linux遍历目录源代码

<pre code_snippet_id"1622396" snippet_file_name"blog_20160324_1_744516" name"code" class"cpp">遍历目录获取整个目录的占用空间: uint64_t dir_space(char *path) {int ret 0;uint64_t space 0;char cur_dir[PATH_MAX …

android studio 手动安装gradle,Android Studio 如何安装Gradle?

今天新下载安装了Android Studio 2.1&#xff0c;启动并新建第一个项目&#xff0c;结果卡在 gradle 上。网上搜原因&#xff0c;得到这个网页&#xff1a;http://blog.csdn.net/maxsky/article/details/50204093。说是要自己下载 gradle的压缩包&#xff0c;查了项目目录下的 …

Label 表达式绑定

Text<%#"总金额为: "Convert.ToString(Convert.ToDecimal(TextBox1.Text)*Convert.ToInt32(TextBox2.Text)%> Page_Load { Page.DataBind(); }转载于:https://www.cnblogs.com/handsomer/p/4150386.html

(转)如果知道dll文件是面向32位系统还是面向64位系统的?

本文为转载文章&#xff0c;原文地址&#xff1a;http://www.cnblogs.com/qguohog/archive/2011/09/13/2174897.html&#xff0c;仅仅是记录供后续使用&#xff0c;如有侵权请通知删除。 在发布dll时&#xff0c;可以选择编译为x86模式、x64模式以及Any Cpu模式等。那么对于已经…

Spring Roo 简介

一直以来&#xff0c;Java/Spring开发被认为是笨重的代表&#xff0c;无法快速生成项目原型和骨架。所以&#xff0c;Spring推出了Spring Roo这个项目&#xff0c;帮助我们快速生成项目原型。本文参考自Spring Roo的官方文档&#xff0c;如果熟悉英文的话可以直接看原文档&…

双缓冲 android,Android 的 SurfaceView 双缓冲应用

075 int index 0;本文引用地址&#xff1a;http://www.eepw.com.cn/article/201610/305442.htm076 try {077 index field.getInt(R.drawable.class);078 } catch (IllegalArgumentException e) {079 // TODO Auto-generated catch block080 e.printStackTrace();081 } catch …

Windows—JDK安装与环境变量配置

本文介绍JDK的安装与环境变量配置。 工具/原料 JDK1.8.0_65WIN7 32bitjdk-8u65-windows-i586.exe方法/步骤 安装JDK 选择安装目录 安装过程中会出现两次 安装提示 。第一次是安装 jdk &#xff0c;第二次是安装 jre 。建议两个都安装在同一个java文件夹中的不同文件夹中。&…

典型案例道出“服务台”的价值

引 言&#xff1a;作为运营管理着庞大IT系统的CIO&#xff0c;相信您或多或少都尝试过&#xff0c;或正建有IT服务台&#xff08;或帮助台&#xff09;&#xff0c;然而您可能依然面临服务效率低下&#xff0c;用户满意度欠佳的 困扰。这其中的原因&#xff0c;多半就在于您的服…

数据的艺术

数据的艺术概念:数据 --程序操作的对象&#xff0c;用于描述客观事物。数据的特点:a. 可以输入到计算机b. 可以被计算机程序处理*数据是一个抽象的概念&#xff0c;将其进行分类得到程序设计语言中的类型。数据元素 -组成数据的基本单位a. 数据项:一个数据元素由若干数据项组成…

处理ajax的session超时

做web开发时&#xff0c;当session超时时&#xff0c;如果不是ajax请求&#xff0c;很简单就能实现跳到指定的页面。但是ajax请求就会有问题。session超时的时候&#xff0c;点击到ajax请求就会弹出一些页面源码文件。 首先建了个拦截器&#xff0c;来判断session超时。用户登录…

菜根谭#249

色欲火炽&#xff0c;而一念及病时便兴似寒灰&#xff1b; 名利饴甘&#xff0c;而一想到死地便味如嚼蜡。 故人常忧死虑病&#xff0c;亦可消幻业而长道心。转载于:https://www.cnblogs.com/star4knight/p/4154590.html

实现物联网项目,你需要提前知道的6件事情

目前为止&#xff0c;对于大多数寻求数字化与服务化转型的制造商来说&#xff0c;实现物联网应用项目仍然是一个很大的挑战。 我们此前做过一项研究&#xff0c;到2016年底,全球企业级物联网项目将超过10000个。但是其中大部分的项目都还是处于初期概念验证(PoC)阶段&#xff0…

android脚本快捷方式,Android:如何创建主屏幕快捷方式启动shell脚本?

答案&#xff1a;您的问题的答案应该是GScript(开放源代码和“根除设备上的任何地方”),但是当脚本完成时,谁想要盯着该模态终端输出屏幕&#xff1f;详情如下.> SManager (free version)将让您将自定义脚本存储在设备的任何位置,即使您使用根设备的内部存储也是如此.它将允…

读书 文摘 笔记

凤凰项目: 一个IT运维的传奇故事 微信商城开发实战 跨境电商多平台运营 活出生命的意义 托马斯阿尔瓦爱迪生 奇迹的一生 阿尔伯特爱因斯坦 固执 自信 专利局 我的世界观 爱因斯坦 艾萨克牛顿 母亲让牛顿停学在家务农&#xff0c;赡养家庭。但牛顿一有机会便埋首书卷&#…

修改Visual Stdio 2010界面,以及添加一些其它VS2010的插件

打开 Tools\Extension Manager&#xff08;工具\扩展管理器&#xff09;。 点联机库。 搜索“visual studio color theme editor”&#xff0c;就能看到一个名为“visual studio color theme editor”的扩展&#xff0c; 下载安装好这个扩展&#xff0c;重新启动 Visual Studio…

【NOIP2013】货车运输

Description A 国有 n 座城市&#xff0c;编号从 1 到 n&#xff0c;城市之间有 m 条双向道路。每一条道路对车辆都有重量限制&#xff0c;简称限重。现在有 q 辆货车在运输货物&#xff0c;司机们想知道每辆车在不超过车辆限重的情况下&#xff0c;最多能运多重的货物。 Input…

杀死应用进程 android,如何杀死Android应用程序启动的logcat进程?

我有Android应用程序,在Service启动实现后面跟着代码&#xff1a;...Process process Runtime.getRuntime().exec("logcat -v time -s " arg);BufferedReader bufferedReader new BufferedReader(new InputStreamReader(process.getInputStream()));...如您所见,我…

Android笔记(六十七) 自定义控件

实际编程中&#xff0c;系统提供的控件往往无法满足我们的需求&#xff0c;一来是样子丑陋&#xff0c;二来是一些复杂的组合需要多次使用的话&#xff0c;每次都写一堆控件的组合会很耗费时间&#xff0c;所以我们将这些组件的组合自定义为一个新的控件&#xff0c;以后使用的…