SQL練習題(1)

聲明:所有題目均是百度搜索,再由自己整理出來的,並非自己出的題。

一,基本表的定義與刪除.

題1: 
用SQL語句創建如下三張表:學生(Student),課程表(Course),和學生選課表(SC),這三張表的結構如表1-1到表1-3所示。

表1-1 Student表結構
列名 說明 數據類型 約束
Sno 學號 字符串,長度爲7 主碼
Sname 姓名 字符串,長度爲10 非空
Ssex 性別 字符串,長度爲2 取‘男’或‘女’
Sage 年齡 整數 取值15~45
Sdept 所在系 字符串,長度爲20 默認爲‘計算機系’

-- DEFAULT ‘默認值’

CREATE TABLE Student(

Sno CHAR(7) COMMENT '學號',

Sname CHAR(10) NOT NULL COMMENT '姓名',

Ssex CHAR(2) COMMENT '性別' CHECK(Ssex='男' OR Ssex='女') ,

Sage INT COMMENT '年齡' CHECK(15 <= Sage AND Sage <= 45),

Sdept CHAR(20) DEFAULT '計算機系' COMMENT '所在系',

PRIMARY KEY (Sno)

);


表1-2Course表結構
列名 說明 數據類型 約束
Cno 課程號 字符串,長度爲10 主碼
Cname 課程名 字符串,長度爲20 非空
Ccredit 學分 整數 取值大於0
Cemster 學期 整數 取值大於0
Period 學時 整數 取值大於0

CREATE TABLE Course

(Cno CHAR(10) COMMENT '課程號' PRIMARY KEY,

Cname CHAR(20) NOT NULL COMMENT '課程名',

Credit INT(11) COMMENT "學分" CHECK(Credit > 0),

Cemster INT(11) COMMENT "學期" CHECK(Semster > 0),

Period INT(11) COMMENT "學時" CHECK(Period > 0)

);

錯誤寫法:

CREATE TABLE Course(

Cno CHAR(10) PRIMARY KEY COMMENT '課程號',

Cname CHAR(20) NOT NULL COMMENT '課程名',

Credit INT(11) CHECK(Credit > 0)  COMMENT "學分",

Cemster INT(11)  CHECK(Semster > 0) COMMENT "學期",

Period INT(11)  CHECK(Period > 0) COMMENT "學時"

);

 

表1-3 SC表結構
列名 說明 數據類型 約束
Sno 學號 字符串,長度爲7 主碼,引用Student的外碼
Cno 課程名 字符串,長度爲10 主碼,引用Course
Grade 成績 整數 取值0~100

-- 設置兩個主鍵時不能寫在單獨列後面

CREATE TABLE SC(

Sno CHAR(7) COMMENT '學號',

Cno CHAR(10) NOT NULL COMMENT '課程名',

Grade INT(11) COMMENT "成績" CHECK(Grade > 0 AND Grade < 100),

FOREIGN KEY (Sno) REFERENCES Student(Sno),

FOREIGN KEY (Cno) REFERENCES Course(Cno),

PRIMARY KEY (Sno, Cno)

);

二,修改表結構題2:
爲SC表添加“選課類別”列,此列的定義爲XKLB char(4).

ALTER TABLE sc ADD XKLB CHAR(4);

題3:
將新添加的XKLB的類型改爲char(6)。
 

ALTER TABLE sc MODIFY XKLB CHAR(6);

題4:
刪除Course表的Period列。

ALTER TABLE Course DROP Period;

 

三,數據查詢功能

表3-1 Student表數據
Sno Sname Ssex Sage Sdept
9512101 李勇 男 19 計算機系
9512102 劉晨 男 20 計算機系
9512103 王敏 女 20 計算機系
9521101 張立 男 22 信息系
9521102 吳賓 女 21 信息系
9521103 張海 男 20 信息系
9531101 錢小平 女 18 數學系
9531102 王大力 男 19 數學系 

INSERT INTO student VALUES

(9512101, '李勇', '男', 19, '計算機系'),

(9512102, '劉晨', '男', 20, '計算機系'),

(9512103, '王敏', '男', 20, '計算機系'),

(9521101, '張立', '男', 22, '信息系'),

(9521102, '吳賓', '男', 21, '信息系'),

(9521103, '張海', '男', 20, '信息系'),

(9531101, '錢小平', '男', 18, '數學系'),

(9531102, '王大力', '男', 19, '數學系');

表3-2 Course表數據
Cno Cname Ccredit Cemester
C01 計算機文化學 3 1
C02 VB 2 3
C03 計算機網絡 4 7
C04 數據庫基礎 6 6
C05 高等數學 8 2
C06 數據結構 5 4


INSERT INTO Course VALUES

('C01', '計算機文化學', 3, 1),

('C02', 'VB', 2, 3),

('C03', '計算機網絡', 4, 7),

('C04', '數據庫基礎', 6, 6),

('C05', '高等數學', 8, 2),

('C06', '數據結構', 5, 4);

表 3-3 SC表數據
Sno Cno Grade XKLB
9512101 c01 90 必修
9512101 c02 86 選修
9512101 c06 <NULL> 必修
9512102 c02 78 選修
9512102 c04 66 必修
9521102 c01 82 選修
9521102 c02 75 選修
9521102 c04 92 必修
9521102 c05 50 必修
9521103 c02 68 選修
9521103 c06 <NULL> 必修
9531101 c01 80 選修
9531101 c05 95 必修
9531102 c05 85 必修


INSERT INTO sc VALUES

(9512101, 'c01', 90, '必修'),

(9512101, 'c02', 86, '選修'),

(9512101, 'c06', NULL, '必修'),

(9512102, 'c02', 78, '選修'),

(9512102, 'c04', 66, '必修'),

(9521102, 'c01', 82, '選修'),

(9521102, 'c02', 75, '選修'),

(9521102, 'c04', 92, '必修'),

(9521102, 'c05', 50, '必修'),

(9521103, 'c02', 68, '選修'),

(9521103, 'c06', NULL, '必修'),

(9531101, 'c01', 80, '選修'),

(9531101, 'c05', 95, '必修'),

(9531102, 'c05', 85, '必修');

 

題5:
用sql語句填寫以上(表3-1 Student表數據、表3-2 Course表數據、表 3-3 SC表數據)數據。


題6:
查詢全體學生的學號與姓名。

SELECT Sno, Sname FROM Student;

題7:
查詢全體學生的姓名,學號和所在系。

SELECT Sno, Sname, Sdept FROM Student;

題8:
查詢全體學生的記錄。

SELECT * FROM Student;           -- * 代表所有

題9:
查詢全體學生的姓名及其出生年份。

SELECT Sname, 2019-Sage AS "出生年份" FROM Student;

題10:
查詢全體學生的姓名和出生年份,並在出生年份列前加入一個列,此列的每行數據均爲“Year of Birth”常量值。

SELECT Sname, '出生年份', 2011-Sage FROM Student;

題11:
在選課表(SC)中查詢有哪些學生選修了課程,並列出學生的學號。

SELECT Sno, XKLB FROM sc WHERE XKLB = '選修';

題12:
查詢計算機系全體學生的姓名。

SELECT Sname, Sdept FROM Student WHERE Sdept = '計算機系';

題13:
查詢所有年齡在20歲以下的學生的姓名及年齡。

SELECT Sname, Sage FROM student WHERE Sage < 20;

題14:
查詢考試成績不及格的學生的學號。

SELECT Sno, Grade FROM sc WHERE Grade < 60;

題15:
查詢年齡在20~23歲之間的學生的姓名,所在系和年齡。

SELECT Sname, Sdept, Sage FROM Student WHERE (20 <= Sage AND Sage <= 23);

SELECT Sname, Sdept, Sage FROM Student WHERE Sage BETWEEN 20 AND 23;

SELECT Sname, Sdept, Sage FROM Student WHERE Sage IN (20,21,22,23);

題16:
查詢年齡不在20~23之間的學生的姓名,所在系和年齡。

SELECT Sname, Sdept, Sage FROM Student WHERE (20 > Sage OR Sage > 23);

SELECT Sname, Sdept, Sage FROM Student WHERE Sage NOT BETWEEN 20 AND 23;

SELECT Sname, Sdept, Sage FROM Student WHERE Sage NOT IN (20,21,22,23);

題17:
查詢信息系,數學系和計算機系學生的姓名和性別。

SELECT Sname, Ssex, Sdept FROM Student WHERE (Sdept = '信息系' OR Sdept = '數學系');

SELECT Sname, Ssex, Sdept FROM Student WHERE Sdept IN('信息系', '數學系');

題18:
查詢既不屬於信息系,數學系,也不屬於計算機系的學生的姓名和性別。
 

SELECT Sname, Ssex, Sdept FROM Student WHERE Sdept NOT IN('信息系', '數學系');

題19:
查詢姓“張”的學生的詳細信息。

SELECT * FROM Student WHERE Sname LIKE '張%';

題20:
查詢學生表中姓“張”,姓“李”和姓“劉”的學生的情況。

SELECT * FROM Student WHERE Sname LIKE '張%' OR Sname LIKE '李%' OR Sname LIKE '劉%';

題21:
查詢名字中第2個字爲“小”或“大”字的學生的姓名和學號。

SELECT Sno, Sname FROM Student WHERE Sname LIKE '_小_' OR Sname LIKE '_大_';

題22:
查詢所有不姓“劉”的學生。
 

SELECT * FROM Student WHERE Sname NOT LIKE '劉%';

題23:
從學生表中查詢學號的最後一位不是2,3,5的學生的情況。

SELECT * FROM Student WHERE Sno NOT LIKE '%2';

題24:
查詢無考試成績的學生的學號和相應的課程號。

SELECT Sno, Cno, Grade FROM sc WHERE Grade IS NULL;

題25:
查詢所有有考試成績的學生的學號和課程號。

SELECT Sno, Cno, Grade FROM sc WHERE Grade IS NOT NULL;

題26:
查詢計算機系年齡在20歲以下的學生的姓名。

SELECT Sname, Sage, Sdept FROM student WHERE Sage < 20;

題27:
將學生按年齡升序排序。

SELECT Sname, Sage, Sdept FROM student ORDER BY Sage;

題28:
查詢選修了課程“c02”的學生的學號及其成績,查詢結果按成績降序排列。
 

SELECT Cno, Grade FROM sc WHERE Cno = 'c02' ORDER BY Grade DESC;

題29:
查詢全體學生的信息,查詢結果按所在系的系名升序排列,同一系的學生按年齡降序排列。

SELECT * FROM student ORDER BY Sdept ASC, Sage ASC;

題30:
統計學生總人數。

SELECT COUNT(*) FROM student;

題31:
統計選修了課程的學生的人數。

SELECT COUNT(XKLB) FROM sc WHERE XKLB = '選修';

題32 :
計算學號爲9512101的學生的考試總成績之和。

SELECT SUM(Grade) FROM sc WHERE Sno = 9512101;

題33:
計算課程“c01”的學生的考試平均成績。

SELECT AVG(Grade) FROM sc WHERE Cno = 'c01';

題34:
查詢選修了課程“c01”的學生的最高分和最低分。

SELECT MAX(Grade), MIN(Grade) FROM sc WHERE Cno = 'c01';

題35:
統計每門課程的選課人數,列出課程號和人數。

SELECT Cno, COUNT(Cno) AS '選課人數' FROM sc GROUP BY Cno;

題36:
查詢每名學生的選課門數和平均成績。

SELECT Sno, COUNT(Cno) AS '選課門數', AVG(Grade) FROM sc GROUP BY Sno;

題37:
查詢選修了3門以上課程的學生的學號。

SELECT Sno FROM SC GROUP BY Sno HAVING COUNT(*) > 3;

題38:
查詢選課門數等於或大於4門的學生的平均成績和選課門數。

SELECT Sno, COUNT(Sno) AS '選課門數', AVG(Grade) AS '平均成績' FROM sc GROUP BY Sno HAVING COUNT(*) >= 4;

題39:
去掉例38中的重複列。

SELECT Sno, COUNT(DISTINCT Sno) AS '選課門數', AVG(Grade) AS '平均成績' 
FROM sc GROUP BY Sno HAVING COUNT(*) >= 4;

四,多表連接查詢。

題40:
查詢每個學生的情況及其選課的情況。

SELECT * FROM student JOIN sc ON student.Sno = sc.Sno;

題41:
查詢計算機系學生的選課情況,要求列出學生的名字,所修課的課程號和成績。

SELECT Sname, Cno, Sdept, Grade FROM student 
LEFT JOIN sc ON student.`Sno` = sc.`Sno` 
WHERE Sdept = '計算機系';

題42:
查詢信息系選修VB課程的學生的成績,要求列出學生姓名,課程名和成績。

SELECT Sname, Cname, Grade FROM student s 
LEFT JOIN sc  ON s.`Sno`=sc.`Sno` 
JOIN course c ON c.`Cno`=sc.`Cno`
WHERE (Cname = 'VB' AND Sdept = '信息系');

題43:
查詢所有選修了VB課程的學生的情況,要求列出學生姓名和所在的系。

SELECT st.Sname, st.Sdept, c.Cname, s.Grade 
FROM student st JOIN sc s ON st.`Sno` = s.`Sno` 
JOIN course cON c.`Cno`=s.`Cno` 
WHERE c.`Cname` = 'VB';

題44:
查詢學生的選課情況,包括選修課程的學生和沒有修課的學生。

SELECT Student.Sno,Sname,Cno,Grade FROM Student
LEFT OUTER JOIN SC ON Student.Sno = SC.Sno;

五,子查詢

題45:
查詢與劉晨在同一個系學習的學生的姓名和所在系(記錄包括劉晨)。

SELECT Sname, Sdept FROM student WHERE Sdept IN(
SELECT Sdept FROM student WHERE Sname = '劉晨'
) ;

題46:
查詢與劉晨在同一個系的其他學生信息(不包括劉晨)。

SELECT * FROM student WHERE Sdept IN(
SELECT Sdept FROM student WHERE Sname = '劉晨') 
AND Sname != '劉晨';

題47:
查詢成績大於90分的學生的學號和姓名。
 

SELECT Sno, Sname FROM student WHERE Sno IN (
SELECT Sno FROM sc WHERE Grade > 90);

題48:
查詢選修了“數據庫基礎”課程的學生的學號和姓名。

SELECT Sno, Sname FROM student WHERE Sno IN (
SELECT Sno FROM sc WHERE Cno IN(
SELECT Cno FROM course WHERE Cname = '數據庫基礎')
);

題49:
查詢選修了課程“c02”且成績高於此課程的平均成績的學生的學號和成績。

SELECT Sno, Grade FROM sc AS s1 WHERE Cno = 'c02' 
AND Grade > (SELECT AVG(Grade) FROM sc WHERE Cno = 'c02');

題50:
查詢 選修 了課程“c01”的學生姓名。

SELECT Sname FROM student WHERE Sno IN (
SELECT Sno FROM sc WHERE Cno = 'c01' AND XKLB = '選修');

題51:
查詢沒有 選修 課程“c01”的學生姓名和所在系。

SELECT Sname, Sdept FROM student WHERE Sno NOT IN (
SELECT Sno FROM sc WHERE XKLB = '選修' AND Cno = 'c01');

題52:
查詢 必修 課程“c01”的學生的姓名和所在系。

SELECT Sname, Sdept FROM student WHERE Sno IN (
SELECT Sno FROM sc WHERE Cno = 'c01' AND XKLB = '必修');

題53:
查詢數學系成績在80分以上的學生的學號,姓名。

SELECT Sno, Sname FROM student WHERE EXISTS (
SELECT * FROM sc WHERE student.`Sno` = sc.`Sno` AND Grade > 80) AND Sdept = '數學系';

題54:
查詢計算機系考試成績最高的學生的姓名。

SELECT * FROM Student WHERE Sno IN (
SELECT Sno FROM (SELECT * FROM sc ORDER BY Grade LIMIT 1) AS c) 
AND Sdept = '計算機系';

六,插入數據
題55:
將新生紀錄(9521105, 陳冬, 男, 18, 信息系)插入到Student表中。

INSERT INTO student VALUE(9521105, '陳冬', '男', 18, '信息系');

題56:
在SC表中插入一新記錄(9521105,c01),成績暫缺。

INSERT INTO sc(Sno, Cno) VALUE(9521105, 'c01');

七,更新數據

題57:
將所有學生的年齡加1。

UPDATE student SET Sage = Sage + 1;

題58:
將“9512101”學生的年齡改爲21歲。

UPDATE student SET Sage = 21 WHERE Sno = 9512101;

題59:
將計算機系學生的成績加5分。

UPDATE sc SET Grade = Grade + 5 WHERE Sno IN(
SELECT Sno FROM student WHERE Sdept='計算機系');

八,刪除數據

題60:
刪除所有學生的選課記錄。

DELETE FROM sc;

TRUNCATE sc;

題61:
刪除所有不及格學生的選課記錄。

DELETE FROM sc WHERE Grade < 60;

題62:
刪除計算機系不及格學生的選課記錄。

delete from SC where Grade < 60 and Sno in (
select Sno from Student where Sdept = '計算機系');

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章