珍藏的資料庫SQL基礎練習題答案

来源:https://www.cnblogs.com/JunCen/archive/2020/05/20/12925253.html
-Advertisement-
Play Games

一,基本表的定義與刪除. 題1: 用SQL語句創建如下三張表:學生(Student),課程表(Course),和學生選課表(SC),這三張表的結構如表1-1到表1-3所示。 表1-1 Student表結構列名 說明 數據類型 約束Sno 學號 字元串,長度為7 主碼Sname 姓名 字元串,長度為1 ...



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

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

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


create table Student(
Sno char(7) primarykey,
Sname char(10) not null,
Ssex char(4) check(Ssex='男' or Ssex='女') ,
Sage number() check(Sage>=15 and Sage<=45),
Sdept char(20) default('電腦系'));
-------------------------------------------------------------------------------------------------------------------


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


create table Course(
Cno char(10) primarykey,
Cname char(20) not null,
Ccredit nuber() check(Ccredit>0) ,
Cemster number() check(Cemster>0),
Period number() check(Period>0));
-----------------------------------------------------------------------------------------------------------------

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

 

create table SC(
Sno char(7),
Cno char(10),

primary key(Sno,Cno),

foreign key (Sno) references Student(Sno),
foreign key (Cno) references.3 Course(Cno),

Grade number() check(Grade>=0 and Grade<=100));

-------------------------------------------------------------------------------------------------------------------

二,修改表結構

題2:
為SC表添加“選課類別”列,此列的定義為XKLB char(4).
alter SC set add XLB char(4) null;

題3:
將新添加的XKLB的類型改為char(6)。
alter table SC alter column XKLB char(6);

題4:
刪除Course表的Period列。
alter from drop column 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(Sno,Sname,Ssex,Sage,Sdept)
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(Cno,Cname,Ccredit,Cemester) values(
'C01','電腦文化學',3,1;
'C02','VB',2,3;
'C03','電腦網路',4,7;
'資料庫基礎',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,'必修')

insert into SC(Sno,Cno,Grade) values('9521102','C02',75,'選修')
insert into SC values('9521102','C04',92,'必修')
insert into SC values('9521102','C05',50,'必修')
insert into SC values('9521103','C02',68,'選修')
insert into SC values('9521103','C06',NULL,'必修')
insert into SC values('9531101','C01',80,'選修')
insert into SC values('9531101','C05',95,'必修')
insert into SC values('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 SC join Student on Student.Sno=SC.Sno;


題9:
查詢全體學生的姓名及其出生年份。
select Sname,2011-Sage as '出生年份';

題10:
查詢全體學生的姓名和出生年份,併在出生年份列前加入一個列,此列的每行數據均為“Year of Birth”常量值。
select Sname,'出生年份',2011-Sage from Student;

題11:
在選課表(SC)中查詢有哪些學生選修了課程,併列出學生的學號。
select distingct Sno from SC;

題12:
查詢電腦系全體學生的姓名。
select Sname from Student where Sdept='電腦系';

題13:
查詢所有年齡在20歲以下的學生的姓名及年齡。
slect Sname,Sage from Student where Sage<20;

題14:
查詢考試成績不及格的學生的學號。
select distingct Sno from SC where Grade <60;

題15:
查詢年齡在20~23歲之間的學生的姓名,所在系和年齡。
select Sname,Sdept,Sage from Student where Sage between 20 and 23;

題16:
查詢年齡不在20~23之間的學生的姓名,所在系和年齡。
select Sname,Sdept,Sage from Student where Sage not between 20 and 23;

題17:
查詢信息系,數學系和電腦系學生的姓名和性別。
select Sname,Ssex from Student where Sdept in ('信息系','數學系','電腦系');

題18:
查詢既不屬於信息系,數學系,也不屬於電腦系的學生的姓名和性別。
select Sname,Ssex from Student where Sdept not in ('信息系','數學系','電腦系');

題19:
查詢姓“張”的學生的詳細信息。
select * from Student where Sname like '張%';

題20:
查詢學生表中姓“張”,姓“李”和姓“劉”的學生的情況。
select * from Student where Sname like '[張李劉]%';

題21:
查詢名字中第2個字為“小”或“大”字的學生的姓名和學號。
select Sname,Sno from Student where Snme like '_[小大]%';

題22:
查詢所有不姓“劉”的學生。
select Sname from Student where Sname not like '劉%';

題23:
從學生表中查詢學號的最後一位不是2,3,5的學生的情況。
select * from where Sno not like '%[235]';

題24:
查詢無考試成績的學生的學號和相應的課程號。
select Sno,Cno from SC where Grade is null;

題25:
查詢所有有考試成績的學生的學號和課程號。
select Sno,Cno from SC where Grade is not null;

題26:
查詢電腦系年齡在20歲以下的學生的姓名。
select Sname from Student where Sdept = '電腦系' and Sage < 20;

題27:
將學生按年齡升序排序。
select * from Student order by Sage;

題28:
查詢選修了課程“c02”的學生的學號及其成績,查詢結果按成績降序排列。
select Sno,Grade from SC where Cno='c02' order by Grade desc;

題29:
查詢全體學生的信息,查詢結果按所在系的系名升序排列,同一系的學生按年齡降序排列。
select * from Student order by Sdept,Sage desc;

題30:
統計學生總人數。
select count(*) from Student;

題31:
統計選修了課程的學生的人數。
select count(distingct Sno) from SC;

題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 as '課程號',count(Sno) as '選課人數' from SC group by Cno;

題36:
查詢每名學生的選課們數和平均成績。
select Sno as '學號',count(*) as '選課門數',avg(Grade) as '平均成績' from SC group by SNo;

題37:
查詢選修了3門以上課程的學生的學號。
select Sno from SC group by Sno having count(*) > 3;

題38:
查詢選課門數等於或大於4門的學生的平均成績和選課門數。
select Sno,avg(Grade) '平均成績',count(*) '選課門數' from SC group by Sno having count(*) >= 4;

四,多表連接查詢。

題39:
查詢每個學生的情況及其選課的情況。
select * from Student join SC on Student.Sno=SC.Sno

題40:
去掉例38中的重覆列。
select Sno,avg(Grade) '平均成績',count(distingct Sno) '選課門數' from SC group by Sno having count(*) >= 4;


題41:
查詢電腦系學生的選課情況,要求列出學生的名字,所修課的課程號和成績。
select Sname,Cno,Grade from Student join SC on Student.Sno=SC.Sno where Sdept = '電腦系';

題42:
查詢信息系選修VB課程的學生的成績,要求列出學生姓名,課程名和成績。
select Sname,Cname,Grade from Student s join SC on s.Sno=SC.Sno join Course c on c.Cno=SC.Cno
where Sdept = '信息系' and Cname = 'VB';

題43:
查詢所有選修了VB課程的學生的情況,要求列出學生姓名和所在的系。
select Sname,Cname,Grade from Student s join SC on s.Sno=SC.Sno join Course c on c.Cno=SC.Cno
where Cname = 'VB';

題44:
查詢與劉晨在同一個系學習的學生的姓名和所在系。
select S2.Sname,S2.Sdept from Student S1 join Student S2 on S1.Sdept = S2.Sdept
where S1.Sname = '劉晨' and S2.Sname !='劉晨';

題45:
查詢學生的選課情況,包括選修課程的學生和沒有修課的學生。
select Student.Sno,Sname,Cno,Grade from Student left outer join SC on Student.Sno = SC.Sno;

五,自查詢。

題46:
查詢與劉晨在同一個系的學生。
select Sno,Sname,Sdept 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 where Cno='c02' and
Grade >(select avg(Grade) from SC where Cno = 'c02');

題50:
查詢選修了課程“c01”的學生姓名。
select Sname from Student
where exists ( select * from SC where Sno = Student.Sno and Cno='c01');

題51:
查詢沒有選修課程“c01”的學生姓名和所在系。
select Sname,Sdept from Student
where not exists ( select * from SC where Sno = Student.Sno and Cno='c01');

六,自查詢。

題52:
查詢選修了課程“c01”的學生的姓名和所在系。
select Sname,Sdept from Student
where exists ( select * from SC where Sno = Student.Sno and Cno='c01');

題53:
查詢數學系成績在80分以上的學生的學號,姓名。
select Sname,Sno from Student
where exists ( select * from SC where Sno = Student.Sno and Grade>=80);

題54:
查詢電腦系考試成績最高的學生的姓名。
select Sname from Student
where exists ( select * from SC where Sno = Student.Sno and max(Grade));

七,插入數據
題55:
將新生紀錄(9521105,陳冬,男,信息系,18歲)插入到Student表中。
insert into Student values('9521105','陳冬','男',18,'信息系');

題56:
在SC表中插入一新記錄(9521105,c01),成績暫缺。
insert into SC values('9521105','c01',null,'必修');

八,更新數據。

題57:
將所有學生的年齡加1。
update Student set Sage = Sage+1;

題58:
將“9512101”學生的年齡改為21歲。
update Student 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;

題61:
刪除所有不及格學生的選課記錄。
delete from SC where Grade < 60;

題62:
刪除電腦系不及格學生的選課記錄。
delete from SC where Grade < 60 and Sno in (select Sno from Student where Sdept = '電腦系');

轉載自:https://www.cnblogs.com/caiyishuai/p/10648909.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這裡分享嵌入式領域有用有趣的項目/工具以及一些熱點新聞,農曆年分二十四節氣,希望在每個交節之日準時發佈一期。 ...
  • 偷個懶,晚上工作忙的太晚,整個複製功能的內容還沒有寫完,這裡先說一下複製功能的簡單應用。 在Redis中,用戶可以通過執行SLAVEOF命令或者設置slaveof選項,讓一個伺服器去複製另一個伺服器,我們稱呼被覆制的伺服器為主伺服器(master),而對主伺服器進行複製的伺服器則被稱為從伺服器(sl ...
  • Redis中的數據類型 字元串 散列 列表 集合 有序集合 Redis中的數據類型 Redis定義了這幾種數據類型: string(字元串) hash(散列) list(列表) set(集合) zset(有序集合) 後面會介紹它們各自的特點和使用場景。可以用TYPE命令來獲取鍵的類型。 字元串 字元 ...
  • 回顧一下,第一篇文章 "大白話 六問數據中台!你想知道的都在這了!" 。把數據中台是什麼?為什麼?有什麼價值?說的明明白白。 數據中台是企業級能力復用平臺,目標是讓數據持續用起來,通過數據中台提供的工具、方法和運行機制,把數據變為一種服務能力,讓數據更方便地被業務所使用 。 今天就來點實際乾貨,把企 ...
  • 腳本: /* 說明:sql server如何通過排序控制insert into ... select ... 語句的記錄插入順序 腳本來源:https://www.cnblogs.com/zhang502219048/p/12925890.html */ create table #t ( id i ...
  • SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE datname='db_name' AND pid<>pg_backend_pid(); drop database db_name; ...
  • 出現ora-31655錯誤的情況 原因:是因為不是同一個schema,導致的問題產生 解決方案: 在導入語句最後添加上remap_schema=old:new 著old是原schema,也就是導出的用戶名,new是想要導入的用戶名 如:這裡有一個expdp導出的dmp文件用戶是test_old,想要 ...
  • 以system用戶登錄,查找需要刪除的用戶: --查找用戶 select * from dba_users; --查找工作空間的路徑select * from dba_data_files; --刪除用戶drop user 用戶名稱 cascade;--刪除表空間與數據文件drop tablespa ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...