SQL Server高级查询
简介
关于数据库,我们经常会听说“增查删改”之类的词语,听起来很简单,但是如果想要准确的获取到需要的数据的话,还是要花点功夫的。下面由我来和大家谈谈高级查询的用法以及和普通查询的区别
高级查询
子查询
语法: 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高级查询的更多相关文章
- sql server 高级查询
--in和not in子查询 --采用in子查询获得参加考试的在读学生名单select StudentId,StudentName from Student where StudentId in(se ...
- 转载 50种方法优化SQL Server数据库查询
原文地址 http://www.cnblogs.com/zhycyq/articles/2636748.html 50种方法优化SQL Server数据库查询 查询速度慢的原因很多,常见如下几种: 1 ...
- Sql Server中查询今天、昨天、本周、上周、本月、上月数据
Sql Server中查询今天.昨天.本周.上周.本月.上月数据 在做Sql Server开发的时候有时需要获取表中今天.昨天.本周.上周.本月.上月等数据,这时候就需要使用DATEDIFF()函数及 ...
- Sql Server参数化查询之where in和like实现详解
where in 的参数化查询实现 首先说一下我们常用的办法,直接拼SQL实现,一般情况下都能满足需要 string userIds = "1,2,3,4"; using (Sql ...
- 【转】Sql Server参数化查询之where in和like实现之xml和DataTable传参
转载至: http://www.cnblogs.com/lzrabbit/archive/2012/04/29/2475427.html 在上一篇Sql Server参数化查询之where in和li ...
- 【转】Sql Server参数化查询之where in和like实现详解
转载至:http://www.cnblogs.com/lzrabbit/archive/2012/04/22/2465313.html 文章导读 拼SQL实现where in查询 使用CHARINDE ...
- SQL Server中查询用户的对象权限和角色的方法
--SQL Server中查询用户的对象权限和角色的方法 -- 查询用户的object权限 exec sp_helprotect NULL, 'sa' -- 查询用户拥有的role exec sp_h ...
- 优化SQL Server数据库查询方法
SQL Server数据库查询速度慢的原因有很多,常见的有以下几种: 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列 ...
- SQL Server 2008 查询所有用户表
SQL Server 2008 查询所有用户表的T-SQL语句是: SELECT * FROM sysobjects WHERE [xtype] = 'U' 或者是: SELECT * FROM sy ...
随机推荐
- 解决ajax跨域请求 (总结)
ajax跨域请求,目前已用几种方法实现: 1)用原生js的xhr对象实现. var url="http://freegeoip.net/json/" ...
- DotNet指定文件显示的尺寸
在项目中开发中,有时候需要将文件的尺寸进行控制,例如需要将文件的尺寸指定为字节,TB等.现在提供一个方法,实现将指定文件的尺寸, 提供:"字节", "KB", ...
- ASP.NET实现微信功能(1)(创建菜单,验证,给菜单添加事件)
LZ实在 不知道怎么起名字了,索性就取了这个名字,开始吧,说实在的,想给自己的平常的学习做一个总结,总是忘了总结.也只能给工作做一个总结了. 我打算用2篇文章来写,第一篇是关于订阅号的,就是这个号,另 ...
- 2.第一个Struts2程序-HelloWorld程序
1.新建Web Project项目:Study_Struts2 2.新建HelloWordAction.java类 3.复制struts.xml文件到src目录下,配置struts.xml文件内容如下 ...
- 谈一谈SQL Server中的执行计划缓存(上)
简介 我们平时所写的SQL语句本质只是获取数据的逻辑,而不是获取数据的物理路径.当我们写的SQL语句传到SQL Server的时候,查询分析器会将语句依次进行解析(Parse).绑定(Bind).查询 ...
- discuz X3.1 源代码阅读,记录代码片段
require_once libfile('function/post'); // /source/function/function_post.php require_once libfile('p ...
- Oracle账户解锁/锁定
1. 首先用系统账号登录: sqlplus /nolog conn /as sysdba 2. 输入命令对账户解锁/锁定: ALTER USER scott ACCOUNT UNLOCK ALTER ...
- MySQL 相关总结
MySQL 优秀在线教程 RUNOOB-SQL 教程 MySQL 常用命令 导出操作 -- 某数据库 全部表 结构和数据 mysqldump -h192.168.8.152 -uroot -p man ...
- spring-stutrs求解答
这里贴上applicationContext里的代码: <?xml version="1.0" encoding="UTF-8"?> <bea ...
- Javascript 创建对象方法的总结
最近看了一下<Javascript高级程序设计(第三版)>,这本书很多人都推荐,我也再次郑重推荐一下.看过之后总得总结一下吧,于是我选了这么一个主题分享给大家. 使用Javascript创 ...