SQL中EXISTS怎么用

连保罗 2019-12-21 23:51:00

推荐回答

Exists方法描述如果在Dictionary对象中指定的关键字存在,返回True,若不存在,返回False。举个例子吧:select*fromawhereexistsselect*frombwherea.id=b.id;a表和b表使用id关联,这条语句的含义是,当b表能够查询出结果时,existsselect*frombwherea.id=b.id子句为真,只有满足exists结果为真时,才会查询出a表的记录。这样解释你明白了吗。
黎益华2019-12-22 00:36:19

提示您:回答为网友贡献,仅供参考。

其他回答

  • 比如在Northwind数据库中有一个查询为SELECTc.CustomerId,CompanyNameFROMCustomerscWHEREEXISTSSELECTOrderIDFROMOrdersoWHEREo.CustomerID=c.CustomerID这里面的EXISTS是如何运作呢?子查询返回的是OrderId字段,可是外面的查询要找的是CustomerID和CompanyName字段,这两个字段肯定不在OrderID里面啊,这是如何匹配的呢? EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False。EXISTS指定一个子查询,检测行的存在。语法:EXISTSsubquery参数:subquery是一个受限的SELECT语句不允许有COMPUTE子句和INTO关键字。结果类型:Boolean如果子查询包含行,则返回TRUE,否则返回FLASE。在子查询中使用NULL仍然返回结果集select*fromTableInwhereexistsselectnull等同于:select*fromTableIn比较使用EXISTS和IN的查询。注意两个查询返回相同的结果。select*fromTableInwhereexistsselectBIDfromTableExwhereBNAME=TableIn.ANAMEselect*fromTableInwhereANAMEinselectBNAMEfromTableEx比较使用EXISTS和=ANY的查询。注意两个查询返回相同的结果。select*fromTableInwhereexistsselectBIDfromTableExwhereBNAME=TableIn.ANAMEselect*fromTableInwhereANAME=ANYselectBNAMEfromTableExNOTEXISTS的作用与EXISTS正好相反。如果子查询没有返回行,则满足了NOTEXISTS中的WHERE子句。结论:EXISTS包括NOTEXISTS子句的返回值是一个BOOL值。EXISTS内部有一个子查询语句SELECT...FROM...,我将其称为EXIST的内查询语句。其内查询语句返回一个结果集。EXISTS子句根据其内查询语句的结果集空或者非空,返回一个布尔值。一种通俗的可以理解为:将外查询表的每一行,代入内查询作为检验,如果内查询返回的结果取非空值,则EXISTS子句返回TRUE,这一行行可作为外查询的结果行,否则不能作为结果。分析器会先看语句的第一个词,当它发现第一个词是SELECT关键字的时候,它会跳到FROM关键字,然后通过FROM关键字找到表名并把表装入内存。接着是找WHERE关键字,如果找不到则返回到SELECT找字段解析,如果找到WHERE,则分析其中的条件,完成后再回到SELECT分析字段。最后形成一张我们要的虚表。WHERE关键字后面的是条件表达式。条件表达式计算完成后,会有一个返回值,即非0或0,非0即为真true,0即为假false。同理WHERE后面的条件也有一个返回值,真或假,来确定接下来执不执行SELECT。分析器先找到关键字SELECT,然后跳到FROM关键字将STUDENT表导入内存,并通过指针找到第一条记录,接着找到WHERE关键字计算它的条件表达式,如果为真那么把这条记录装到一个虚表当中,指针再指向下一条记录。如果为假那么指针直接指向下一条记录,而不进行其它操作。一直检索完整个表,并把检索出来的虚拟表返回给用户。EXISTS是条件表达式的一部分,它也有一个返回值true或false。在插入记录前,需要检查这条记录是否已经存在,只有当记录不存在时才执行插入操作,可以通过使用EXISTS条件句防止插入重复记录。INSERTINTOTableInANAME,ASEX SELECTtop1''张三'',''男''FROMTableInWHEREnotexistsselect*fromTableInwhereTableIn.AID=7EXISTS与IN的使用效率的问题,通常情况下采用exists要比in效率高,因为IN不走索引,但要看实际情况具体使用:IN适合于外表大而内表小的情况;EXISTS适合于外表小而内表大的情况。
    樊成钢2019-12-22 00:54:14
  • 简单点说ifEXISTSselect*fromtbwherename=''abc''就是这样用上面这句话的意思是查询表tb找name=''abc''的列如果有找到exists返回真否则返回假加上if语句还可以取反操作ifnotexists。
    边冬霞2019-12-22 00:18:27
  • WHEREEXISTSSELECTT.IDFROMTEACHERTWHERET.ID=S.TID等同于WHERES.TIDINSELECTT.IDFROMTEACHER但exists的效率要高很多你原来那句相当于没有任何关联关系所以相当于SELECTS.NAMEFROMSTUDENTS不懂hi我。
    龙少红2019-12-22 00:06:04
  • exists:强调的是是否返回结果集,不要求知道返回什么,比如:selectnamefromstudentwheresex=''m''andmarkexistsselect1fromgradewhere...,只要exists引导的子句有结果集返回,那么exists这个条件就算成立了,大家注意返回的字段始终为1,如果改成“select2fromgradewhere...”,那么返回的字段就是2,这个数字没有意义。所以exists子句不在乎返回什么,而是在乎是不是有结果集返回。而exists与in最大的区别在于in引导的子句只能返回一个字段,比如:selectnamefromstudentwheresex=''m''andmarkinselect1,2,3fromgradewhere...,in子句返回了三个字段,这是不正确的,exists子句是允许的,但in只允许有一个字段返回,在1,2,3中随便去了两个字段即可。而notexists和notin分别是exists和in的对立面。exists1桔子水果202019-7-21香蕉水果152019-7-32青菜蔬菜192019-7-2注意in只允许有一个字段返回有一种方法可以实现:SELECTId,Name,Class,COUNT,DateFROMtable1tWHEREDate=SELECTMAXDateFROMtable1WHEREId=t.Id。
    黄盛珠2019-12-21 23:54:36

相关问答

VF常用SQL语句大全SQL是结构化查询语言,查询是SQL语言的重要组成部分,但不是全部,SQL还包括数据定义,数据操纵和数据控制功能等部分.如今SQL已成为关系数据库的标准数据语言,所以现在的关系数据库管理系统都支持SQL.FOXPRO从2.5FORDOS版式就开始支持SQL,现在VISUALFOXPRO当然在之方面更加完善,以下是VF经常用到SQL语句.--语句功能--数据操作SELECT--从数据库表中检索数据行和列INSERT--向数据库表添加新数据行DELETE--从数据库表中删除数据行UPDATE--更新数据库表中的数据--数据定义CREATETABLE--创建一个数据库表DROPTABLE--从数据库中删除表ALTERTABLE--修改数据库表结构CREATEVIEW--创建一个视图DROPVIEW--从数据库中删除视图CREATEINDEX--为数据库表创建一个索引DROPINDEX--从数据库中删除索引CREATEPROCEDURE--创建一个存储过程DROPPROCEDURE--从数据库中删除存储过程CREATETRIGGER--创建一个触发器DROPTRIGGER--从数据库中删除触发器CREATESCHEMA--向数据库添加一个新模式DROPSCHEMA--从数据库中删除一个模式CREATEDOMAIN--创建一个数据值域ALTERDOMAIN--改变域定义DROPDOMAIN--从数据库中删除一个域--数据控制GRANT--授予用户访问权限DENY--拒绝用户访问REVOKE--解除用户访问权限--事务控制COMMIT--结束当前事务ROLLBACK--中止当前事务SETTRANSACTION--定义当前事务数据访问特征--程序化SQLDECLARE--为查询设定游标EXPLAN--为查询描述数据访问计划OPEN--检索查询结果打开一个游标FETCH--检索一行查询结果CLOSE--关闭游标PREPARE--为动态执行准备SQL语句EXECUTE--动态地执行SQL语句DESCRIBE--描述准备好的查询---局部变量declare@idchar10--set@id=10010001select@id=10010001---全局变量---必须以@@开头--IFELSEdeclare@xint@yint@zintselect@x=1@y=2@z=3if@x>@yprintx>y--打印字符串x>yelseif@y>@zprinty>zelseprintz>y--CASEusepanguupdateemployeesete_wage=casewhenjob_level=’1’thene_wage*1.08whenjob_level=’2’thene_wage*1.07whenjob_level=’3’thene_wage*1.06elsee_wage*1.05end--WHILECONTINUEBREAKdeclare@xint@yint@cintselect@x=1@y=1while@x<3beginprint@x--打印变量x的值while@y<3beginselect@c=100*@x+@yprint@c--打印变量c的值select@y=@y+1endselect@x=@x+1select@y=1end--WAITFOR--例等待1小时2分零3秒后才执行SELECT语句waitfordelay’01:02:03’select*fromemployee--例等到晚上11点零8分后才执行SELECT语句waitfortime’23:08:00’select*fromemployee。
本文主要分析了in和exists的区别与执行效率的问题:in可以分为三类:1、形如select*fromt1wheref1in''a'',''b'',应该和以下两种比较效率。select*fromt1wheref1=''a''orf1=''b''或者select*fromt1wheref1=''a''unionallselect*fromt1f1=''b''你可能指的不是这一类,这里不做讨论。2、形如select*fromt1wheref1inselectf1fromt2wheret2.fx=''x'',其中子查询的where里的条件不受外层查询的影响,这类查询一般情况下,自动优化会转成exist语句,也就是效率和exist一样。3、形如select*fromt1wheref1inselectf1fromt2wheret2.fx=t1.fx,其中子查询的where里的条件受外层查询的影响,这类查询的效率要看相关条件涉及的字段的索引情况和数据量多少,一般认为效率不如exists。除了第一类in语句都是可以转化成exists语句的,一般编程习惯应该是用exists而不用in.A,B两个表,1当只显示一个表的数据如A,关系条件只一个如ID时,使用IN更快:select*fromAwhereidinselectidfromB2当只显示一个表的数据如A,关系条件不只一个如ID,col1时,使用IN就不方便了,可以使用EXISTS:select*fromAwhereexistsselect1fromBwhereid=A.idandcol1=A.col13当只显示两个表的数据时,使用IN,EXISTS都不合适,要使用连接:select*fromAleftjoinBonid=A.id所以使用何种方式,要根据要求来定。这是一般情况下做的测试:测试结果:setstatisticsioonselect*fromsysobjectswhereexistsselect1fromsyscolumnswhereid=syscolumns.idselect*fromsysobjectswhereidinselectidfromsyscolumnssetstatisticsiooff47行受影响表''syscolpars''。扫描计数1,逻辑读取3次,物理读取0次,预读2次,lob逻辑读取0次,lob物理读取0次,lob预读0次。表''sysschobjs''。扫描计数1,逻辑读取3次,物理读取0次,预读0次,lob逻辑读取0次,lob物理读取0次,lob预读0次。1行受影响44行受影响表''syscolpars''。扫描计数47,逻辑读取97次,物理读取0次,预读0次,lob逻辑读取0次,lob物理读取0次,lob预读0次。表''sysschobjs''。扫描计数1,逻辑读取3次,物理读取0次,预读0次,lob逻辑读取0次,lob物理读取0次,lob预读0次。1行受影响setstatisticsioonselect*fromsyscolumnswhereexistsselect1fromsysobjectswhereid=syscolumns.idselect*fromsyscolumnswhereidinselectidfromsysobjectssetstatisticsiooff419行受影响表''syscolpars''。扫描计数1,逻辑读取10次,物理读取0次,预读15次,lob逻辑读取0次,lob物理读取0次,lob预读0次。表''sysschobjs''。扫描计数1,逻辑读取3次,物理读取0次,预读0次,lob逻辑读取0次,lob物理读取0次,lob预读0次。1行受影响419行受影响表''syscolpars''。扫描计数1,逻辑读取10次,物理读取0次,预读0次,lob逻辑读取0次,lob物理读取0次,lob预读0次。表''sysschobjs''。扫描计数1,逻辑读取3次,物理读取0次,预读0次,lob逻辑读取0次,lob物理读取0次,lob预读0次。1行受影响测试结果总体来讲exists比in的效率高:效率:条件因素的索引是非常关键的把syscolumns作为条件:syscolumns数据大于sysobjects用in扫描计数47,逻辑读取97次,用exists扫描计数1,逻辑读取3次把sysobjects作为条件:sysobjects的数据少于syscolumnsexists比in多预读15次。