SQL Server学习之路(六):“增删改查”之“查”
0.目录
1.前言
2.最基本的SQL查询语句
3.select...from...
- 3.1 “*”与“Top num *”
- 3.2 查询指定列
- 3.3 Isnull函数:判断空值
- 3.4 使用"+"将"列"与"字符串"连接起来(使用as重命名)
4.order by
5.where
- 5.1 比较运算符
- 5.2 or 或 and
- 5.3 Like "%" 或 "_" 通配符
- 5.4 in 或 not in
- 5.5 is null 或 is not null
- 5.6 between...and...
6.group by & having
- 6.1 常用的聚合函数&经典查询语句
- 6.2 count
- 6.3 Avg、Min、Max、Sum
- 6.4 group by & having 的作用
1.前言
增删改查都是对数据的操作,其中“查”对应的SQL语句便是“select”,也就是“选择”的意思。
本篇主要介绍数据的查询,主要使用SQL Server提供的T-SQL语句查询数据。
本篇主要参考了慕课网的视频SQL Server基础--T-SQL语句,以及部分参考了网易云课堂的视频SQLServer数据库基础,另外还参照了一下w3school的SQL 教程。如果有时间的话,推荐去看一下视频课程。
2.最基本的SQL查询语句
最基本的SQL查询语句语法如下:
SELECT <table fields list>
FROM <table names list>
WHERE <row constraints specification>
GROUP BY <grouping specification>
HAVING <grouping selection specification>
ORDER BY <order rules specification>
Tips & Tricks:
1、Select...From... 语句是必须的。
2、Where, group by 以及 order by 三个语句不是必须的。
上面的语法先不必死记硬背,以下会依次介绍他们的功能。
3.select...from...
3.1 “*”与“Top num *”
select * from student
-- "*"代表选择所有,即查询student表中的所有数据
select Top 5 * from student
-- "Top num"代表选择前num行,即查询student表中的前num行数据

3.2 查询指定列
select sno, sname
from student
-- 如果只想看student表中的学号和姓名列,那就只需要查询指定列

3.3 Isnull函数:判断空值
select cno, cname, isnull(cpno, ''), ccredit
from course
-- isnull(cpno,'')将cpno中的NULL值置空,用户就看不到NULL了,只能看见空白。但是列的名字会变为(No column name/无列名)
原表如下:

查询出的表如下:

3.4 使用"+"将"列"与"字符串"连接起来(使用as重命名)
select sno, sname as '姓名',
'学号是' + sno + '的同学叫' + sname +'.' as IDname
from student
-- 使用"+"将两列进行合并
-- 使用"as"将列名重命名

4.order by
原表:

4.1 asc(正序)
select *
from FactSalesQuota
order by SalesAmountQuota
-- 默认就是asc正序排序(从小到大)

4.2 desc(倒序)
select *
from FactSalesQuota
order by EmployeeKey desc
-- desc倒序排序(从大到小)

4.3 其他
select *
from FactSalesQuota
order by EmployeeKey desc, SalesAmountQuota
-- 先按EmployeeKey倒序排序,如果EmployeeKey相同再按SalesAmountQuota排序

5.where
5.1 比较运算符
-- 比较运算符有 =、>、<、>=、<=、<>("<>"是不等于的意思)
select *
from student
where sdept = '理学院'
select *
from student
where sage >= 20
select *
from student
where ssex <> '男'

5.2 or 或 and
-- and就是两个条件都要满足,or就是满足一个条件即可
-- and就是两个条件都要满足,or就是满足一个条件即可
select *
from student
where sdept = '理学院' and sage >= 20
select *
from student
where sage >= 20 or sno = '0001'
select *
from student
where ssex = '男' and ssex = '女'

可以看到,没有既是"男"又是"女"的学生,所以第三张表没有任何数据。
5.3 Like "%" 或 "_" 通配符
原表:

-- like代表要模糊查找
-- "%"代表任意符,表示可以有任何东西也可以没有
-- "_"代表占位符,就是有且仅有一个字母,但是忘记了那个字母具体是什么
select *
from FactCallCenter
where Shift like 'AM'
-- like'Shift'代表精确查找'AM',相当于where Shift = 'AM'

select *
from FactCallCenter
where Shift like 'PM%'
-- like 'PM%'代表以PM开头的所有字符串
-- like '%PM'代表以PM结尾的所有字符串

select *
from FactCallCenter
where Shift like '%M%'
-- like '%M%'代表M前面和后面都可以有任何东西

select *
from FactCallCenter
where Shift like 'PM_'
-- like 'PM_'代表PM后面有且仅有一个字母或者数字,不能是空

5.4 in 或 not in
select *
from FactCallCenter
where DateKey in ('20101101', '20101105', '20101110')

select *
from FactCallCenter
where WageType not in ('weekday')
-- 相当于where WageType <> 'weekday'

5.5 is null 或 is not null
select *
from DimProduct
where ProductSubcategoryKey is null
select *
from DimProduct
where ProductSubcategoryKey is not null

5.6 between...and...
操作符 BETWEEN ... AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。(在SQLServer中两个端点的值都会包括)
例如:
select *
from FactCallCenter
where DateKey between '20101105' and '20101107'
-- DateKey在20101105-20101107范围内的所有数据
-- 如果要取不在这个范围的则可以用以下语句
select *
from FactCallCenter
where DateKey not between '20101105' and '20101107'

6.group by & having
6.1 常用的聚合函数 & 经典查询语句
常用的函数有:
count、Avg、Min、Max、Sum
6.2 count
select count(*)
from FactCallCenter
where Shift = 'AM'
-- count用来统计符合条件的行数

6.3 Avg、Min、Max、Sum
select
Avg(LevelOneOperators) as AverageLevelOneOperators
,Min(LevelOneOperators) as MinimumLevelOneOperators
,Max(LevelOneOperators) as MaximumLevelOneOperators
,Sum(LevelOneOperators) as SummaryLevelOneOperators
from FactCallCenter
-- Avg平均值,Min最小值,Max最大值,Sum求和

6.4 group by & having 的作用
select Shift, Max(LevelOneOperators) as LevelOneOperators最大值
from FactCallCenter
where Shift is not null
group by Shift
-- group by Shift表示对不同的Shift值,分别求LevelOneOperators的最大值

select Shift, Max(LevelOneOperators) as LevelOneOperators最大值
from FactCallCenter
where Shift is not null
group by Shift
having Max(LevelOneOperators) > 2
-- group by Shift表示对不同的Shift值,分别求LevelOneOperators的最大值
-- having Max(LevelOneOperators) > 2 进一步对结果进行筛选

SQL Server学习之路(六):“增删改查”之“查”的更多相关文章
- 在SQL Server中对视图进行增删改
原文:在SQL Server中对视图进行增删改 Lesktop开源IM发布以后,有一些网友问及如何在嵌入IM后与自己网站的用户系统整合(即如何让嵌入的IM直接使用网站原有的用户数据库,而不需要将已有的 ...
- SQL Server学习之路(三):“增删改查”之“增”
0.目录 1.前言 2.通过SSMS添加数据 3.通过SQL语句添加数据 3.1 添加单条数据 3.2 添加多条数据 4.通过其他表导入数据 4.1 通过数据库中的其他表导入数据 4.2 通过exce ...
- SQL Server学习之路(五):“增删改查”之“改”
0.目录 1.前言 2.通过SSMS修改数据 3.通过SQL语句修改数据 3.1 修改单列数据 3.2 修改多列数据 1.前言 增删改查都是对数据的操作,其中"改"对应的SQL语句 ...
- SQL Server学习之路(四):“增删改查”之“删”
0.目录 1.前言 2.通过SSMS删除 3.通过SQL语句删除 3.1 删除单行数据 3.2 删除所有行数据 3.3 删除表和数据库 1.前言 增删改查都是对数据的操作,其中"删" ...
- SQL Server学习之路(七):Python3操作SQL Server数据库
0.目录 1.前言 2.准备工作 3.简单测试语句 4.提交与回滚 5.封装成类的写法 1.前言 前面学完了SQL Server的基本语法,接下来学习如何在程序中使用sql,毕竟不能在程序中使用的话, ...
- Sql Server xml 类型字段的增删改查
1.定义表结构 在MSSM中新建数据库表CommunicateItem,定义其中一个字段ItemContentXml 为xml类型 2.编辑表数据,新增一行,发现xml类型不能通过设计器录入数据. 需 ...
- sql server连接oracle并实现增删改查
需要一个软件ODAC112040Xcopy_64bit 我连接的oracle是11g r2 sqlserver 是 2016 软件下载 https://pan.baidu.com/s/1OpYmpR ...
- SQL Server学习之路(一):建立数据库、建立表
0.目录 1.前言 2.建立数据库 2.1 通过SSMS建立数据库 2.2 通过SQL语句建立数据库 3.建立表 3.1 通过SSMS建立表 3.2 通过SQL语句建立表 1.前言 配置是win10+ ...
- SQL Server学习之路:建立数据库、建立表
1.前言 配置是win10+SQL Server 2012,使用的GUI管理工具是SQL Server 2012自带的SQL Server Management Studio(以下简称SSMS).本系 ...
随机推荐
- Python Fabric远程自动部署简介
Fabric是一个Python(2.5-2.7)库,用于简化使用SSH的应用程序部署或系统管理任务. 它提供的操作包括:执行本地或远程shell命令,上传/下载文件,以及其他辅助功能,如提示用户输入. ...
- .10-Vue源码之Watcher(1)
上一节最后再次调用了mount函数,我发现竟然跳到了7000多行的那个函数,之前我还说因为声明早了被覆盖,看来我错了! 就是这个函数: // Line-7531 Vue$3.prototype.$mo ...
- mongo+mongoose+express
直接上指令: //*代表自定义名字 //使用数据库 use * //检查当前数据库 db //查询数据库列表 show dbs //查询当前数据库集合 show collections //插入文档自 ...
- JavaScript--我发现,原来你是这样的JS:面向对象编程OOP[2]--(创建你的那个对象吧)
一.介绍 我们继续面向对象吧,这次是面向对象编程的第二篇,主要是讲创建对象的模式,希望大家能从博客中学到东西. 时间过得很快,还是不断的学习吧,为了自己的目标. 二.创建对象 1.前面的创建对象方式 ...
- css给div添加阴影效果
直接上代码: <style type="text/css">.mydiv{ width:250px; height:auto; border:#909090 1px ...
- 二叉搜索树的第 k 个结点
题目 给定一颗二叉搜索树,请找出其中的第k小的结点,即将二叉树中所有元素从小到大排序的第 k 个结点. 解析 按中序遍历二叉搜索树就可以获得一个非递减的序列,此时第 k 个就为答案.实际上我们只需要按 ...
- JavaScript 数组基本操作
简介 数组操作无论是在JavaScript中还是在其他语言中都是很常见.经常会用到的,现在我把JavaScript 数组基本操作整理一下,供大家参考学习.里边包含我自己的见解以及案例,希望能够帮助大家 ...
- app.config 配置多项 配置集合 自定义配置
C#程序的配置文件,使用的最多的是appSettings 下的<add key="Interval" value="30"/>,这种配置单项的很方便 ...
- bzoj1001(对偶图最短路)
显然是个最大流问题. 边数达到了10^6级别,显然用dinic算法会TLE 对于一个平面图来说,当然用对偶图的最短路来求最小割(最大流) SPFA转移的时候注意判断边界情况 应该要开longlong才 ...
- C#利用UdpClient发送广播消息
首先写个接受消息的客户端.这里偷了点懒,new UdpClient(11000)就是用Udp方式侦听11000端口,侦听任何发送到11000端口的消息都会接收到. 代码 : ); Byte[] sen ...