关于sql中的exists,写上和不写是否没啥区别,是否只是提高了执行效率

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于sql中的exists,写上和不写是否没啥区别,是否只是提高了执行效率相关的知识,希望对你有一定的参考价值。

不是啊,两者是有区别的EXISTS
指定一个子查询,检测行的存在。
语法
EXISTS subquery
参数
subquery
是一个受限的 SELECT 语句 (不允许有 COMPUTE 子句和 INTO 关键字)。有关更多信息,请参见 SELECT 中有关子查询的讨论。
结果类型
Boolean
结果值
如果子查询包含行,则返回 TRUE
使用 NOT EXISTS 的子查询
NOT EXISTS 与 EXISTS 的工作方式类似,只是如果子查询不返回行,那么使用 NOT EXISTS 的 WHERE 子句会得到令人满意的结果。

例如,要查找不出版商业书籍的出版商的名称:

USE pubs
SELECT pub_name
FROM publishers
WHERE NOT EXISTS
(SELECT *
FROM titles
WHERE pub_id = publishers.pub_id
AND type = 'business')

下面是结果集:

pub_name
----------------------------------------
Binnet & Hardley
Five Lakes Publishing
Ramona Publishers
GGG&G
Scootney Books
Lucerne Publishing

(6 row(s) affected)

下面的查询查找已经不销售的书的名称。

USE pubs
SELECT title
FROM titles
WHERE NOT EXISTS
(SELECT title_id
FROM sales
WHERE title_id = titles.title_id)

下面是结果集:

title
----------------------------------
The Psychology of Computer Cooking
Net Etiquette

(2 row(s) affected)
参考技术A Exists 方法 描述如果在 Dictionary 对象中指定的关键字存在,返回 True,若不存在,返回 False。语法object.Exists(key)Exists 方法语法有如下几部分:部分描述Object必需的。始终是一个 Dictionary 对象的名字。Key必需的。在 Dictionary 对象中搜索的 Key 值。
Exists的用处不在于提高执行效率 还有很多用处的
=====你可以去看看百度百科里面的Exists====本回答被提问者和网友采纳

python定义类()中写object和不写的区别

python定义类()中写object和不写的区别

这里需要说明一下:

  • python3中,类定义默认继承object,所以写不写没有区别

  • 但在python2中,并不是这样

所以此内容是针对python2的,当然python3默认继承,不代表我们就傻乎乎的让程序自动继承,自己却不知道其底层区别,所以了解此内容还是很有必要的!

测试代码如下:

# -.- coding:utf-8 -.-

class Person:
    """
    不带object
    """
    name = "zhengtong"


class Animal(object):
    """
    带有object
    """
    name = "chonghong"

if __name__ == "__main__":
    x = Person()
    print "Person", dir(x)

    y = Animal()
    print "Animal", dir(y)

输出如下:

Person ['__doc__', '__module__', 'name']
Animal ['__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', 
'__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', 
'__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'name']

Person类很明显能够看出区别,不继承object对象,只拥有了__doc__ , module 和 自己定义的name变量, 也就是说这个类的命名空间只有三个对象可以操作.

Animal类继承了object对象,拥有了好多可操作对象,这些都是类中的高级特性。

对于不太了解python类的同学来说,这些高级特性基本上没用处,但是对于那些要着手写框架或者写大型项目的高手来说,这些特性就比较有用了,比如说tornado里面的异常捕获时就有用到__class__来定位类的名称,还有高度灵活传参数的时候用到__dict__来完成等。

  • python2中不继承object的类叫经典类,继承object的类叫做新式类。

  • 我们平时写程序时,不妨养成良好的习惯,将object类继承上。

以上是关于关于sql中的exists,写上和不写是否没啥区别,是否只是提高了执行效率的主要内容,如果未能解决你的问题,请参考以下文章

关于sql中in 和 exists 的效率问题,in真的效率低吗

python定义类()中写object和不写的区别

python定义类()中写object和不写的区别

java中Class<T>类型和不写<T>的区别

SQL关于IN和EXISTS的用法和区别的比较

oracle中in,not in和exists,not exists之间的区别