Ⅰ sql 中 exists 是怎么回事啊 怎么用啊 老师没讲懂 呵呵 高手都来帮忙啊
exists 是指:是否存在 的意思
例如你要新建一个新的数据库 但是不知道以前SQLSERVER里是否已经存在该数据库了 则可以使用如下语句
IF EXISTS (SELECT * FROM SYSDATABASES WHERE NAME = 'TEST')
DROP DATABASE 'TEST'
该句意思为:在数据库总记录中查找是否已存在名为‘TEST’的数据库,
如果存在(IF EXISTS) 则执行DROP操作,呵呵 能理解了吧
按照LZ发的题目来解答的话WHERE NOT EXISTS的意思就是为,“不存在于”子查询返回的记录中
Ⅱ 数据库问题exists 和not exists如何使用
exists和not exists我认为最大的特点就是可以使sql语句变得简单,一句话完成很复杂的操作,因为它本身具有循环的特点。
比如(b2是两个表的主键):
update tab1 as a set a.a1=b.a1 where exit(select b.a1 from tab2 as b where b.b2=a.b2);
上面的语句实现的功能是,根据b.b2=a.b2条件循环检索tab2表当检索出一个b.a1的值时,根据a.b2这个主键更新tab1表中相应的记录,当循环到exit后面没有结果产生时sql结束。
not exists 和exists 恰好相反。
※一定记住他和in、not in 是不一样的,他们是数据库内置的循环检索。
我知道的就这些希望对你有帮助。
Ⅲ sql中exists是什么意思,怎么讲解
SQL EXISTS:
EXISTS 运算符用于判断查询子句是否有记录,如果有一条或多条记录存在返回 True,否则返回 False。
具体语法参考:
-from shulanxt
回答不易,望楼主采纳哦~
Ⅳ 数据库sql语句中为什么exists关键字 要比 in 关键字执行效率高
exists是根据子查询有无记录返回确定条件是否成立,如果有记录返回,条件成立,如果子查询未返回记录,条件不成立,不对子查询结果进行匹配,所以速度较快;in要对子查询返回的结果用in关键字前面的值逐个进行匹配,如果匹配成功条件成立,匹配不成功条件不成立,所以速度较慢。
Ⅳ 数据库的exists用法啊,我真的难以拐过弯来啊,怎么理解比如下面的例子:
exists语法可以这样理解,执行查询areas表,并且逐条调用exists语句去匹配,如果在deals表中有匹配项则返回1(true),没有匹配项则返回0(false),返回1的话就显示记录,返回0的话不显示该行记录(这里显示的是areas表的记录,要理解,你现在只是查询areas表,deals表只是拿过来用一下而已),然后进行下一条记录的匹配。
关键是你要想象成他是一条一条记录去匹配的,也就是说areas表中每一行记录都会在deals全表中搜索匹配项,只要存在匹配(可以是一对一也可以是一对多匹配)立即返回1;如果搜索到deals表尾依然没有匹配项,这时候才返回0。
如果懂了请采纳,不懂的话继续追问。
Ⅵ 数据库sql的exists
这么记,两个not exists就是 两个exists
你这句话意思就是从student中拿出一个记录(假设a)再从course拿出一个(假设b),然后和sc表比较,如果a的学号与表sc中某一记录(这个记录假设为c)相等且同时b的课程号与该记录(c)中的学号相等的话,则该记录(a)就是一个结果记录,然后再与sc其他记录比较,知道sc记录扫描完,之后从course中再拿一条记录(假设为d),此时就是记录a和d和sc中每条记录比较,满足条件的就输出,等course记录扫描完毕后从最外层表student拿出一条然后在从头扫描course表盒sc表。以此类推。这个是顺序由外到内再到外的。
Ⅶ 数据库中select语句的存在量词exists怎么使用
select*fromstudentawhereexists(select1fromstudentbwhereb.name='张三'andb.college=a.college)
Ⅷ 数据库中IN 和EXISTS有什么区别
没有什么区别,两者都是包含的意思,但是esists的效率比in要高。建议别用in,影响效率 ,如果只有两三个条件,就用or代替 ,如果值 比较多,就用exists.例如 select * from table where ( name = '1' or name ='2') 别写成name in ('1','2')如果数据量比较大select * from table where name exists (select name from table2);
Ⅸ sql中in和exist语句的区别
两者都能实现表功能查询,主要区别如下:
1、适用表的类型不同。
in是子查询为驱动表,外面的表为被驱动表,故适用于子查询结果集小而外面的表结果集大的情况。
exists是外面的表位驱动表,子查询里面的表为被驱动表,故适用于外面的表结果集小而子查询结果集大的情况。
2、子查询关联不同。
exists一般都是关联子查询。对于关联子查询,必须先执行外层查询,接着对所有通过过滤条件的记录,执行内层查询。外层查询和内层查询相互依赖,因为外层查询会把数据传递给内层查询。
in则一般都是非关联子查询,非关联子查询则必须先完成内层查询之后,外层查询才能介入。
3、执行次数不同。
IN 语句:只执行一次,确定给定的值是否与子查询或列表中的值相匹配。in在查询的时候,首先查询子查询的表,然后将内表和外表做一个笛卡尔积,然后按照条件进行筛选。所以相对内表比较小的时候,in的速度较快。
EXISTS语句:执行次数根据表的长度而定。指定一个子查询,检测行的存在。遍历循环外表,然后看外表中的记录有没有和内表的数据一样的。匹配上就将结果放入结果集中。
Ⅹ SQL中EXISTS怎么用
EXISTS在SQL中的作用是:检验查询是否返回数据。
select a.* from tb a where exists(select 1 from tb where name =a.name)返回真假,当 where 后面的条件成立,则列出数据,否则为空。
exists强调的是是否返回结果集,不要求知道返回什么。比如:select name from student where sex = 'm' and mark exists(select 1 from grade where ...)
只要exists引导的子句有结果集返回,那么exists这个条件就算成立了,大家注意返回的字段始终为1
如果改成“select 2 from grade where ...”,那么返回的字段就是2,这个数字没有意义。所以exists子句不在乎返回什么,而是在乎是不是有结果集返回。
(10)数据库esists扩展阅读:
Exists 方法描述如果在 Dictionary对象中指定的关键字存在,返回True,若不存在,返回False。
语法object.Exists(key)Exists 方法语法有如下几部分:部分描述Object必需的。始终是一个 Dictionary对象的名字。Key必需的,在 Dictionary对象中搜索的Key值。
exist相当于存在量词:表示集合存在,也就是集合不为空只作用一个集合.
例如 exist P表示P不空时为真; not exist P表示p为空时为真in表示一个标量和一元关系的关系。
例如:s in P表示当s与P中的某个值相等时为真; s not in P 表示s与P中的每一个值都不相等时为真。
exits与not exits
exists(sql 返回结果集为真)
not exists(sql 不返回结果集为真)
如果not exists子查询只有自己本身的查询条件,这样只要子查询中有数据返回,就证明是false,结果在整体执行就无返回值;一旦跟外面的查询关联上,就能准确查出数据。