珍藏的資料庫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
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...