简介

    关于数据库,我们经常会听说“增查删改”之类的词语,听起来很简单,但是如果想要准确的获取到需要的数据的话,还是要花点功夫的。下面由我来和大家谈谈高级查询的用法以及和普通查询的区别


高级查询

    子查询

          语法:  select   ...列名...   from   表1   where   列1   (逻辑运算符,大于'>',等于'='...)   ( select   ...列名...   from   表2   where   列2   (逻辑运算符,大于'>',等于'='...) 1)

          简化:  select   ...   from   表1   where   列1   >   (子查询)

          描述:  1.子查询就是一个查询语句又嵌套了一个查询语句。比如你想要以一列中筛选出的数据来作为条件去查询另一列中的数据。其中标红的部分称为子查询,而蓝色部分就是父查询。这只是一种称呼。

               2.子查询还可以用于不同的表间查询,就像是表连接查询。以A表筛选出来的数据作为条件去查询B表中的数据。想必大家都了解表连接查询,其中最重要的一点就是表间要有主外键引用关系,所以这

             也成为了子查询和表连接查询的不同之处。子查询在表连接查询的基础上,还可以用于没有表间连接的情况。所以子查询比表连接查询更为强大,可用用于多种场合。

               3.子查询通常用于查询的筛选条件,就是where后面的条件。而表连接查询常用于查看多表的数据,就是只做查看数据操作。

               4.需要确保子查询语句不会返回多个值,可以用逻辑运算符。否则会报错。但也有可以包含多个值的子查询,后文会讲到。

      IN子查询和NOT IN子查询

          IN子查询语法:select   ...列名...   from   表1   where   列1   IN   ( select   ...列名...   from   表2   where   列2   (逻辑运算符,大于'>',等于'='...) 1)

          简化:  select   ...   from   表1   where   列1   IN   (子查询)

          NOT IN子查询语法:select   ...列名...   from   表1   where   列1   NOT IN   ( select   ...列名...   from   表2   where   列2   (逻辑运算符,大于'>',等于'='...) 1)

          简化:  select   ...   from   表1   where   列1   NOT IN   (子查询)

          描述:  1.可以明显的看出,(IN子查询和NOT IN子查询)和前文的子查询语法上的区别只是where后面的逻辑运算符变成了IN和NOT IN。其他方面没有任何区别。

               2.(IN子查询和NOT IN子查询)和前文的子查询性质基本上一样,只是IN子查询中的子查询语句可以返回多个值的,IN子查询会将这些值都作为条件来判断。而NOT IN则是取反。是不是很像普通查询

             中的 [] 和 between 1 and 10 呢?条件都是一个范围的值。(这里需要注意,只能是一列的多个值。)

      EXISTS和NOT EXISTS子查询

          语法:  IF EXISTS(子查询语句)

                ...语句...

          描述:  EXISTS一般用于if语句的条件检测。如果子查询的结果非空,EXISTS就返回true,执行if结构内的语句,否则返回false,不执行if结构内的语句。而NOT EXISTS则是将返回的结果取反。


总结

    可以用到子查询的地方非常多。子查询语句可以嵌套在SQL语句中任何表达式出现的位置。SELECT语句、from子句、where子句、Group by子句、having子句......,还可以嵌套多层...

    虽然子查询很强大,但使用哪种查询并不重要,重要的是我们需要哪种查询。


附加代码

ps:如若对此文有疑义,欢迎提出。

SQL Server高级查询的更多相关文章

  1. sql server 高级查询

    --in和not in子查询 --采用in子查询获得参加考试的在读学生名单select StudentId,StudentName from Student where StudentId in(se ...

  2. 转载 50种方法优化SQL Server数据库查询

    原文地址 http://www.cnblogs.com/zhycyq/articles/2636748.html 50种方法优化SQL Server数据库查询 查询速度慢的原因很多,常见如下几种: 1 ...

  3. Sql Server中查询今天、昨天、本周、上周、本月、上月数据

    Sql Server中查询今天.昨天.本周.上周.本月.上月数据 在做Sql Server开发的时候有时需要获取表中今天.昨天.本周.上周.本月.上月等数据,这时候就需要使用DATEDIFF()函数及 ...

  4. Sql Server参数化查询之where in和like实现详解

    where in 的参数化查询实现 首先说一下我们常用的办法,直接拼SQL实现,一般情况下都能满足需要 string userIds = "1,2,3,4"; using (Sql ...

  5. 【转】Sql Server参数化查询之where in和like实现之xml和DataTable传参

    转载至: http://www.cnblogs.com/lzrabbit/archive/2012/04/29/2475427.html 在上一篇Sql Server参数化查询之where in和li ...

  6. 【转】Sql Server参数化查询之where in和like实现详解

    转载至:http://www.cnblogs.com/lzrabbit/archive/2012/04/22/2465313.html 文章导读 拼SQL实现where in查询 使用CHARINDE ...

  7. SQL Server中查询用户的对象权限和角色的方法

    --SQL Server中查询用户的对象权限和角色的方法 -- 查询用户的object权限 exec sp_helprotect NULL, 'sa' -- 查询用户拥有的role exec sp_h ...

  8. 优化SQL Server数据库查询方法

    SQL Server数据库查询速度慢的原因有很多,常见的有以下几种: 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列 ...

  9. SQL Server 2008 查询所有用户表

    SQL Server 2008 查询所有用户表的T-SQL语句是: SELECT * FROM sysobjects WHERE [xtype] = 'U' 或者是: SELECT * FROM sy ...

随机推荐

  1. 淘宝web前端开发岗面试经历及感悟

    今天下午四点接到淘宝UED的面试电话,很突然,很激动.现在怀着淡淡的忧伤为之文以志一下. 1.自我介绍一下. 我xx时候毕业,在xx公司任xx职务,主要负责xx balabala.(怕公司同事听到,接 ...

  2. jQuery.grep()

    什么是jQuery.grep()? jQuery.grep()是一个查找满足过滤函数的数组元素的函数.原始数组不受影响,返回值为数组. 用法介绍: 写法: jQuery.grep( array, fu ...

  3. jQuery-1.9.1源码分析系列(十一) DOM操作续——克隆节点

    什么情况下使用到克隆节点? 我们知道在对DOM操作过程中如果直接使用节点会出现节点随操作而变动的情况.比如对节点使用.after/.before/.append等方法后,节点被添加到新的地方,原来的位 ...

  4. 查看.NET Core源代码通过Autofac实现依赖注入到Controller属性

    一.前言 在之前的文章[ASP.NET Core 整合Autofac和Castle实现自动AOP拦截]中,我们讲过除了ASP.NETCore自带的IOC容器外,如何使用Autofac来接管IServi ...

  5. 利用闭包解决for循环里onclick事件不能捕捉实时i值问题

    问题描述 我们都知道,如果我们对于一组元素(相同的标签)同时进行onclick事件处理的时候(在需要获取到索引的时候),一般是写一个for循环,但是onclick是一个异步调用的,所以会带来一个问题, ...

  6. iOS 视图控制器 (内容根据iOS编程编写)

    视图控制器是  UIViewController 类或其子类对象.每个视图控制器都负责管理一个视图层次结构,包括创建视图层级结构中的视图并处理相关用户事件,以及将整个视图层次结构添加到应用窗口. 创建 ...

  7. 7.DataAnnotations(数据注解)【Code-First 系列】

    EF Code-First提供了一系列的数据注解的特性,你可以将其应用到你的领域类和属性中,数据注解属性重写了EF默认的约定. System.ComponentModel.DataAnnotation ...

  8. 【Basics of Entity Framework】【EF基础系列1】

    EF自己包括看视频,看MSDN零零散散的学了一点皮毛,这次打算系统学习一下EF.我将会使用VS2012来学习这个EF基础系列. 现在看看EF的历史吧: EF版本 相关版本特性介绍 EF3.5 基于数据 ...

  9. 【原创】Java编译器对String的优化

    首先看以下的代码: public static void main(String[] arge) { String str1 = new String("1234"); Strin ...

  10. seajs的使用--主要了解模块化

    一个使用sea.js的Demo sea.js可以解决命名问题,js文件间的依赖等. index.html内容如下: <!DOCTYPE html> <html xmlns=" ...