SQL SERVER之数据查询
本篇主要解说查询语句,全部的演示样例都会依照以下这张表进行。
stuID |
stuName |
age |
sex |
11090241031 |
王小虎 |
21 |
男 |
11090241032 |
王小六 |
22 |
男 |
11090241033 |
张三 |
23 |
男 |
1.使用where子句查询表中满足条件的记录
比較查询
算术比較查询
算术比較中经常使用的就是所谓的>、<、<>、=、!<(不小于)、!=(不等于)等,比較的语法例如以下
select*
from T_student
where age!>30
select*
from T_student
where stuName<>
'王小七'
注意:在where子句中,假设比較的是数值型数据,则能够省略单引號,假设是字符串或者日期的话,须要用单引號引起来
Between and
用来查询指定条件范围的记录
select*
from T_student
where agebetween 3
and 45
注意:between and的查询的记录包含两个边界值
IN运算符查询与列表匹配的记录
使用IN运算符能够查询与列表匹配的记录
select*
from T_student
where agein(32,15)
注意:在SQL语句中也能够使用not in运算符来排除一些记录。
逻辑查询
在SQL中逻辑运算符主要包含AND、OR和NOT三种。
AND:用来同一时候满足多个条件的记录
OR:用来满足多个条件中的当中随意一个条件
NOT:用来满足反条件的记录
select*
from T_student
where agein(30,15)and
stuName ='王小虎'
(假设有一个条件为False的话,就不会显示结果)
select*
from T_student
where agein(32,15)or
stuName ='王小虎'
(仅仅要满足不论什么一个条件就能够显示记录)
select*
from T_student
where agenot
in(32,15)
(查询的是反条件记录,也就是不满足年龄在32和15的记录)
复杂逻辑
复杂逻辑事实上就是AND、OR、NOT的运算符使用的组合,正如我们所知运算符也有先后顺序
NOT>AND>OR
select*
from T_student
where agenot
in(32,15)OR
stuName ='王小六'
(依据先后顺序可知,查询的是年龄不是32和15或者名字是王小六的记录)
空值查询
在使用SQL语句时,有时可能遇到该字段中没有值,那么就称为空值(null),查询语句也很easy.
select*
from T_student
where stuNameIS
NOT NULL
(查询表汇总名字不是空值的记录)
Like模糊查询
使用LIKE操作符实现模糊查询
在使用SQL时,可能有时会遇到一种情况,不能全然确定自己要查找的信息,可是这些信息又有一些明显的特征,那么就能够採取以下的模糊查询
匹配随意单个字符
通配符“_”表示匹配单个字符,在查询中能够用到
select*
from T_student
where stuName like
'王_虎'
(表示查询王*虎的记录)
匹配0个或者多个字符
通配符“%”表示匹配0个或者多个字符,即一个%能够表示一个字符或者多个字符
select*
from T_student
where stuName like
'王%'
(表示名字中首字符石王的记录)
通配符[]
字符列中的不论什么单一字符
select*
from T_student
where stuName like
'[王菲]%'
(表示姓名以王或者菲开头的记录)
通配符[^]
表示不在字符列中的不论什么单一字符
select * from T_student where stuName like '[^菲]%'
(表示姓名不是已菲开头的记录)
转义字符
在使用SQL运行模糊查询时,假设数据表某个字段本身就包括通配符时,又该怎么办
(1):在须要转义的“%”或者是“_”前加一个转义符,该转义符能够是一个随意字符
(2):在ESCAPEkeyword后指定该转义符的名称
select * from T_student where sutID like '%$_%' ESCAPE '$'
(该查询语句表示,ID中包括_的记录,当中转义符$已经把_转义)
---------------------------------------------------------------------------------------
2.数据表的分组操作
表中的数据的排序和分组
我们在使用SQL语句查询操作时,可能查询出的语句是没有规律的,那么为了更好的观察自己查到的结果能够对其进行排序。
GROUP BY
通过ORDER BY子句能够对查询结果指定的列进行升序或降序,这取决于后面的keyword
select * from T_student order by age desc
(将查出后的结果按降序排序)
注意:ORDER BY子句仅仅是对终于结果进行排序,不能用在select子查询中的select语句中,并且ORDER BY子句的位置必须放在全部子句的最后,也就是说,假设查询语句中有多个子句的话,那么ORDER
BY子句必须放在这些子句之后
经常使用的聚合函数
所谓的聚合函数就是统计函数,主要是对得到的数据进行排序求值等操作
函数 |
功能 |
COUNT(列表达式) |
计算给定列或者表示式中非空行数 |
COUNT(*) |
计算数据表中的总行数,包含空值 |
MAX(列表达式) |
计算给定列中或者表达式中的最大值 |
MIN(列表达式) |
计算给定列或者表达式中的最小值 |
SUM(列表达式) |
计算给定列或者表达式中全部的总和 |
AVG(列表达式) |
计算给定列或者表达式中的全部值得平均值 |
使用GROUP BY子句对表中数据进行分组
GROUP by子句能够依据数据列的多个数据查询出来的结果进行分组
select age, count(stuname)from t_student whereage <50 group by age order by age
(以年龄进行分组,而且统计每一个年龄段的学生的数目)
使用having限制分组后的查询结果
假设要对分组后的结果限制查询条件,就能够使用having语句,该语句放在GROUP BY语句的后面
select age, count(stuname)from t_student whereage <50 group by age having age >15 order by age
(跟上面的同样,仅仅只是又多了年龄的限制,必须大于15)
限制结果集行数
有些时候,我们并不希望看到查出的结果的所有,仅仅显示几行就可,尤其当在分页操作中的时候,仅仅关心前几条记录就OK了,这时候就须要对结果集进行限制
语法:select top n {precent}列名1,列名2 from表名
Top:keyword,表示限制结果集行数的keyword
N:表示限制结果集行数
Precent:表示返回查询的结果集中的前N%的行数
selecttop 1
agefromt_student
where age
<50
(表示仅仅返回一行)
SQL SERVER之数据查询的更多相关文章
- sql server数据库数据查询成功
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding= ...
- SQL Server 中数据查询注意事项
1.查询语句不用区分大小写,而且即使每张表的表名或者列名出现大写字母,在写查询语句的时候也不用区分大小写,查询结果保持一致,所以查询语句小写即可. 2.在写查询语句的时候列名不需要带单引号,数值型的字 ...
- Sql Server 存储过程中查询数据无法使用 Union(All)
原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...
- SQL Server 变更数据捕获(CDC)监控表数据
一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现过程(Realization) 补充说明(Addon) 参考文献(References) ...
- 【转】SQL Server T-SQL高级查询
SQL Server T-SQL高级查询 高级查询在数据库中用得是最频繁的,也是应用最广泛的. Ø 基本常用查询 --select select * from student; //查询student ...
- SQL Server查询优化方法(查询速度慢的原因很多,常见如下几种) .
今天看到一位博友的文章,觉得不错,转载一下,希望对大家有帮助,更多文章,请访问:http://blog.haoitsoft.com 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺 ...
- SQL SERVER 2000 & SQL SERVER 2005 数据缓存依赖
一.SQL SERVER 7.0/2000和SQL SERVER 2005的简介及比较 1.1 SQL SERVER 7.0/2000 SQL SERVER 7.0/2000没有提供内置的支持 ...
- 《转》SQL Server 2008 数据维护实务
SQL Server 2008 数据维护实务 http://blog.csdn.net/os005/article/details/7739553 http://www.cnblogs.com/xun ...
- SQL Server GUID 数据迁移至MongoDB后怎样查看?
关键字:SQL Server NEWID():BSON:MongoDB UUID 1.遇到的问题和困惑 SQL Server中的NEWID数据存储到MongoDB中会是什么样子呢?发现不能简单的通过此 ...
随机推荐
- linq中的临时变量
有一个字符串数组: string[]arrStr={"123","234","345","456"}; 现在想得到该数组 ...
- arduino电子琴(2015-11-04)
前言 这是论坛上一个坛友问的问题,想做一个可变音调的电子琴,想着正好练练手,就顺手做一下. 接线图
- [Swust OJ 85]--单向公路(BFS)
题目链接:http://acm.swust.edu.cn/problem/0085/ Time limit(ms): 5000 Memory limit(kb): 65535 Descriptio ...
- BZOJ 1787: [Ahoi2008]Meet 紧急集合( 树链剖分 )
这道题用 LCA 就可以水过去 , 但是我太弱了 QAQ 倍增写LCA总是写残...于是就写了树链剖分... 其实也不难写 , 线段树也不用用到 , 自己YY一下然后搞一搞就过了...速度还挺快的好像 ...
- 深入理解GCD ( 二 )
转自@nixzhu的GitHub主页(译者:Riven.@nixzhu),原文<Grand Central Dispatch In-Depth: Part 2/2> 欢迎来到GCD深入理解 ...
- 缩略图类库--ThumbLib使用简介
//加载类库文件 require_once 'path/to/ThumbLib.inc.php'; //实例化类库,传入你要处理的图片的地址可以是网络地址,也可以是本地地址 $thumb = PhpT ...
- Linux常用命令 新手必看
文件和目录cd /home 进入 '/ home' 目录'cd .. 返回上一级目录cd ../.. 返回上两级目录cd 进入个人的主目录cd ~user1 进入个人的主目录cd - 返回上次所在的目 ...
- 在SSH整合框架中经常会用到Service层,请问大家这个Service层有什么具体的作用,可不可以不用这个Service层呢?
有效地分离数据访问层(DAO)和业务层(SERVICE),使之各司其职,举例说明:如果DAO层访问数据库,得到的数据根据业务需要要进行加密,那么取数据和把数据加密就是2个步骤,访问数据和业务逻辑加工, ...
- Windows Phone 8初学者开发—第18部分:在页面间导航
原文 Windows Phone 8初学者开发—第18部分:在页面间导航 原文地址: http://channel9.msdn.com/Series/Windows-Phone-8-Developm ...
- C++第13周(春)项目1 - 点、圆的关系
课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759.内有完整教学方案及资源链接 [项目1 - 点.圆的关系](1)先建立一个P ...