最新消息: 关于Git&GitHub 版本控制你了解多少?
您现在的位置是:群英 > 数据库 > MySQL数据库 >
SQL Server子查询什么时候用?用法是什么?
网络发表于 2021-08-28 17:40 次浏览

    SQL Server子查询什么时候用?一般,当由where子句指定的搜索条件指向另一张表时,就需要使用子查询或嵌套查询了,那么SQL Server子查询的用法是什么呢?下面我们一起来深入了解看看。

    1 子查询

    子查询是一个嵌套在select、insert、update或delete语句或其他子查询中的查询。任何允许使用表达式的地方都可以使用子查询。

    1.1语法规则:

    子查询的select查询总使用圆括号括起来不能包括compute或for browse子句如果同时指定top子句,则可能只包括order by子句子查询最多嵌套32层,个别查询可能会不支持32层嵌套任何可以使用表达式的地方都可以使用子查询,主要它返回的是单个值如果某个表只出现在子查询中而不出现在外部查询中,那么该表中的列就无法包含在输出中

    1.2 语法格式:

    where 查询表达式 [not] in(子查询)where 查询表达式 比较运算符 [any|all] (子查询)where [not] exists (子查询)

    2 嵌套查询

    嵌套查询是指将一个查询块嵌套在另一个查询块的where子句或having短语的条件中的查询。

    嵌套查询中上层的查询块称为外侧查询或父查询,下层查询块称为内层查询或子查询。SQL语言允许多层嵌套,但是在子查询中不允许出现order by子句,order by子句只能用在最外层的查询中。

    嵌套查询的处理方法是:先处理最内侧的子查询,然后一层一层地向上处理,直到最外层的查询块。

    2.1 简单的嵌套查询

    子查询的运算符含有=、<>、<、>、<=、>=

    三个查询:

    第一个:查询年纪>25的老师所教的学生

    第二个:查询年纪>25的老师

    第三个:验证查询到的学生信息

    对比:当子查询中的分那会的结果不是一个时,父查询无法正常工作

    2.2 带IN的嵌套查询

    当子查询返回一系列值时,适合带IN的嵌套查询。

    2.3 NOT IN

    2.4 SOME

    2.5 ANY

    2.6 ALL

    2.7 EXIST

    以上就是关于sql server子查询的介绍了,希望对大家学习和理解sql server子查询有帮助,想要了解更多sql server子查询的知识,请关注群英网络其它相关文章。

标签:sql server子查
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
上一篇:没有了
下一篇:没有了
相关信息推荐