文章詳情頁
SQL Server單表數據查詢舉例詳解
瀏覽:80日期:2023-05-02 10:03:27
目錄
- 一、向SQL Server中導入數據
- 二、例題
- 1.查詢所有學生的全部信息
- 2.查詢學生的學號和姓名
- 3.查詢所有學生的姓名和出生年
- 4. 查詢所有學生的姓名和出生年,要求列名是漢字形式
- 5.查詢CS系的所有學生信息
- 6.查詢CS系的所有男同學信息
- 7.查詢年齡在18到20之間的學生信息
- 8.查詢年齡不在18到20之間的學生信息
- 9.查詢所在系為CS和JD的學生信息
- 10.查詢姓張的學生的信息
- 11.查詢姓名只有兩個字且姓李的學生的學號和姓名
- 12.查詢沒有成績的學生的學號和課程號
- 13.消除重復行:查看CS系的年齡情況
- 14.查詢前三個同學的信息
- 15.統計男學生人數
- 16.統計sc表中選修過課程的學生人數(注意要去掉重復選課的學生的學號)
- 17.從表sc中查詢所有成績中的最高分和最低分
- 18.統計學號為1204304102的學生的總成績和平均成績
- 三、小結
- (1) 有三種方法可以指定列名
- (2)根據名字的信息查詢題目類總結
- (3)查詢知識拓展
- 總結
一、向SQL Server中導入數據
導入成功之后,可以點開表格查看內容:
(如下圖即導入成功)
其他表同理可得,也可以同時導入
二、例題
1.查詢所有學生的全部信息
SELECT * FROM student
2.查詢學生的學號和姓名
SELECT sno,sname FROM student
3.查詢所有學生的姓名和出生年
SELECT sname,YEAR(GETDATE())-sageFROM student
4. 查詢所有學生的姓名和出生年,要求列名是漢字形式
SELECT sname 姓名,YEAR(GETDATE())-sage 出生年FROM student
5.查詢CS系的所有學生信息
select * FROM student WHERE sdept="CS"
6.查詢CS系的所有男同學信息
select * FROM student WHERE sdept="CS" AND ssex="男"
7.查詢年齡在18到20之間的學生信息
(1)方法一
select * from student where sage>=18 and sage<=20
(2)方法二
select * from student where sage BETWEEN "18" AND "20"
8.查詢年齡不在18到20之間的學生信息
(1)方法一
select * from student where sage<18 or sage>20
(2)方法二
select * from student where sage not BETWEEN "18" AND "20"
9.查詢所在系為CS和JD的學生信息
(1)方法一
select * from student where sdept="CS" or sdept="JD"
(2)方法二
select * from student where sdept in("CS","JD")
10.查詢姓張的學生的信息
select * from student where sname like"張%"
11.查詢姓名只有兩個字且姓李的學生的學號和姓名
select sno,sname from student WHERE sname LIKE "李_";
12.查詢沒有成績的學生的學號和課程號
select * from sc WHERE grade IS NULL;
13.消除重復行:查看CS系的年齡情況
select DISTINCT sage FROM student WHERE sdept="cs"
14.查詢前三個同學的信息
select TOP 3 * from student
15.統計男學生人數
(1)方法一
select COUNT(sno) 男生人數 from student where ssex="男"
(2)方法二
select COUNT(*) AS 男生人數 from student where ssex="男"
16.統計sc表中選修過課程的學生人數(注意要去掉重復選課的學生的學號)
select COUNT(distinct sno) from sc
17.從表sc中查詢所有成績中的最高分和最低分
select max(grade) 最高分,MIN(grade) 最低分 from sc
18.統計學號為1204304102的學生的總成績和平均成績
select SUM(grade) 總分,AVG(grade) 平均分 from sc where sno="1204304102"
三、小結
(1) 有三種方法可以指定列名
- I. 列名 列標題(例如:sname 姓名)
- II. 列名 AS 列標題(例如:sname AS 姓名)
- III.列標題=列名(例如:姓名=列標題)
select sname 姓名,YEAR(GETDATE())-sage as 出生年,院系=sdept from student
(2)根據名字的信息查詢題目類總結
查詢姓張的學生的信息
select * from student where sname like"張%"
查詢姓黃的學生的信息(當姓氏后面只有一個字時)
select * from student where sname like"黃_"
查詢名字中有“文”這個字的學生的信息
select * from student where sname like"_文_"
(3)查詢知識拓展
查詢前三個同學的信息
select TOP 3 * from student
查詢課程編號是‘2102’的課程分數降序排列
select grade from sc where cno="2102" order by grade desc
查詢課程編號是‘2102’的課程分數降序排列的前兩名
select TOP 2 grade from sc where cno="2102" order by grade desc
總結
到此這篇關于SQL Server單表數據查詢的文章就介紹到這了,更多相關SQLServer單表數據查詢內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!
標簽:
MsSQL
上一條:SQL Server的子查詢詳解下一條:SQL Server的死鎖說明
排行榜