SQL Server单表数据查询举例详解
时间:2023-10-27来源:系统城装机大师作者:佚名
一、向SQL Server中导入数据
data:image/s3,"s3://crabby-images/19730/1973020fc0414a8465015169542259a46c917444" alt=""
data:image/s3,"s3://crabby-images/96e59/96e59012ad608db57ff3ab532f22f4d09091d6ef" alt=""
data:image/s3,"s3://crabby-images/01ee8/01ee86f744357bf252bbcd4a0aab372210851024" alt=""
data:image/s3,"s3://crabby-images/a2f50/a2f501a22089bc80987668659e6147d3a427593b" alt=""
data:image/s3,"s3://crabby-images/429ae/429aef1a90cfde08653ea39f69a5b1d2573ec4a8" alt=""
data:image/s3,"s3://crabby-images/d811f/d811f253cbf886c62867d297a34eecdfccc0ac01" alt=""
data:image/s3,"s3://crabby-images/ab9a3/ab9a37ebfb355b5d1dbca342dc29d80609d1b09f" alt=""
data:image/s3,"s3://crabby-images/e0af3/e0af33897a13f8a5d7fdc41e3cd82cd89336c943" alt=""
data:image/s3,"s3://crabby-images/0827e/0827eb758d531faf0c41c6d51c0a7adec0087d7a" alt=""
导入成功之后,可以点开表格查看内容:
(如下图即导入成功)
其他表同理可得,也可以同时导入
data:image/s3,"s3://crabby-images/ccf40/ccf40dff22af32514ee959d8c37444987f379318" alt=""
二、例题
1.查询所有学生的全部信息
data:image/s3,"s3://crabby-images/1cd4d/1cd4debb9b8fcd837b42b075449d76edc7df7166" alt=""
2.查询学生的学号和姓名
1 |
SELECT sno,sname FROM student |
data:image/s3,"s3://crabby-images/3a1b2/3a1b2e66c42fcefaf1b50f77eb8ad800e31a6777" alt=""
3.查询所有学生的姓名和出生年
1 |
SELECT sname, YEAR (GETDATE())-sageFROM student |
data:image/s3,"s3://crabby-images/6c1b2/6c1b2acbe85f2e0869b86d307195d678dda19190" alt=""
4. 查询所有学生的姓名和出生年,要求列名是汉字形式
1 |
SELECT sname 姓名, YEAR (GETDATE())-sage 出生年 FROM student |
data:image/s3,"s3://crabby-images/e00da/e00daf9b751e715e6c071555fd24131d0c99d5df" alt=""
5.查询CS系的所有学生信息
1 |
select * FROM student WHERE sdept= 'CS' |
data:image/s3,"s3://crabby-images/c1532/c153237960b5324bf335e0b24f81a72ecbe2f826" alt=""
6.查询CS系的所有男同学信息
1 |
select * FROM student WHERE sdept= 'CS' AND ssex= '男' |
data:image/s3,"s3://crabby-images/7ede5/7ede5890a7e133aad9b517fdc209257cf7bf15e6" alt=""
7.查询年龄在18到20之间的学生信息
(1)方法一
1 |
select * from student where sage>=18 and sage<=20 |
data:image/s3,"s3://crabby-images/99a89/99a89f1c7985ed037f9e7b684c320aec8c3171ee" alt=""
(2)方法二
1 |
select * from student where sage BETWEEN '18' AND '20' |
data:image/s3,"s3://crabby-images/69acf/69acf13a2c9d4646d924603b87495da5193f4d88" alt=""
8.查询年龄不在18到20之间的学生信息
(1)方法一
1 |
select * from student where sage<18 or sage>20 |
data:image/s3,"s3://crabby-images/5dc43/5dc436b1df8f68ed89c949a2ae8c75cdbbca26c8" alt=""
(2)方法二
1 |
select * from student where sage not BETWEEN '18' AND '20' |
data:image/s3,"s3://crabby-images/944ec/944ec2d5f0db2f3be3191754885aa3c266f450cb" alt=""
9.查询所在系为CS和JD的学生信息
(1)方法一
1 |
select * from student where sdept= 'CS' or sdept= 'JD' |
data:image/s3,"s3://crabby-images/a8d0d/a8d0dd212c2a39860b01cdfaf377a9fbf770136e" alt=""
(2)方法二
1 |
select * from student where sdept in ( 'CS' , 'JD' ) |
data:image/s3,"s3://crabby-images/ef716/ef71688fa050bc38179962f6005f6e7b750c3d5d" alt=""
10.查询姓张的学生的信息
1 |
select * from student where sname like '张%' |
data:image/s3,"s3://crabby-images/2ddcc/2ddcc64a4f54b39c92e8690be2c3a4de4bcec234" alt=""
11.查询姓名只有两个字且姓李的学生的学号和姓名
1 |
select sno,sname from student WHERE sname LIKE '李_' ; |
data:image/s3,"s3://crabby-images/c55a9/c55a90f38baf409de11ec9845696b9be732a0d1c" alt=""
12.查询没有成绩的学生的学号和课程号
1 |
select * from sc WHERE grade IS NULL ; |
data:image/s3,"s3://crabby-images/3a280/3a28099f3fefce6af9766b0fe3a5fb3300a59eba" alt=""
13.消除重复行:查看CS系的年龄情况
1 |
select DISTINCT sage FROM student WHERE sdept= 'cs' |
data:image/s3,"s3://crabby-images/cfddc/cfddc6ddde7fba705e999ed43521b86733b6c7f4" alt=""
14.查询前三个同学的信息
1 |
select TOP 3 * from student |
data:image/s3,"s3://crabby-images/2bce5/2bce543e7221b35ad537c88a0a2709a7850a7c0d" alt=""
15.统计男学生人数
(1)方法一
1 |
select COUNT (sno) 男生人数 from student where ssex= '男' |
data:image/s3,"s3://crabby-images/5e45a/5e45a7c59c8fbbc81e47fe7e807287354ab81d3f" alt=""
(2)方法二
1 |
select COUNT (*) AS 男生人数 from student where ssex= '男' |
data:image/s3,"s3://crabby-images/31ef3/31ef385a2437e5a2bf58fdac0a8008ceafc0e51f" alt=""
16.统计sc表中选修过课程的学生人数(注意要去掉重复选课的学生的学号)
1 |
select COUNT ( distinct sno) from sc |
data:image/s3,"s3://crabby-images/307b3/307b3e5a4ce6b27b51a8c0d5f1d6f20947f78e25" alt=""
17.从表sc中查询所有成绩中的最高分和最低分
1 |
select max (grade) 最高分, MIN (grade) 最低分 from sc |
data:image/s3,"s3://crabby-images/9156b/9156b8659e2c20bdca6389675a95d4a2528a939b" alt=""
18.统计学号为1204304102的学生的总成绩和平均成绩
1 |
select SUM (grade) 总分, AVG (grade) 平均分 from sc where sno= '1204304102' |
data:image/s3,"s3://crabby-images/68e92/68e922acf4cb2f751aa8cbee33d69d10d66364e5" alt="."
三、小结
(1) 有三种方法可以指定列名
- I. 列名 列标题(例如:sname 姓名)
- II. 列名 AS 列标题(例如:sname AS 姓名)
- III.列标题=列名(例如:姓名=列标题)
1 |
select sname 姓名, YEAR (GETDATE())-sage as 出生年,院系=sdept from student |
data:image/s3,"s3://crabby-images/60d03/60d03355722546b6c02acc5ca7351f7be8802874" alt=""
(2)根据名字的信息查询题目类总结
查询姓张的学生的信息
1 |
select * from student where sname like '张%' |
查询姓黄的学生的信息(当姓氏后面只有一个字时)
1 |
select * from student where sname like '黄_' |
查询名字中有“文”这个字的学生的信息
1 |
select * from student where sname like '_文_' |
(3)查询知识拓展
查询前三个同学的信息
1 |
select TOP 3 * from student |
查询课程编号是‘2102’的课程分数降序排列
1 |
select grade from sc where cno= '2102' order by grade desc |
查询课程编号是‘2102’的课程分数降序排列的前两名
1 |
select TOP 2 grade from sc where cno= '2102' order by grade desc |
总结
到此这篇关于SQL Server单表数据查询的文章就介绍到这了
相关信息
-
SQL Server 数据库中的收缩数据库和文件操作
收缩数据文件通过将数据页从文件末尾移动到更靠近文件开头的未占用的空间来恢复空间,在文件末尾创建足够的空间后,可取消对文件末尾的数据页的分配并将它们返回给文件系统,本文给大家介绍SQL Server 数据库中的收缩数据...
2023-10-27
-