當前位置:首頁 » 編程語言 » sql查出選過課的學生
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql查出選過課的學生

發布時間: 2022-11-26 01:58:00

A. 資料庫sql語句中 查詢選修了全部課程的學生的學號和姓名 理解

樓主別著急!
為好理解我們先從這條SQL語句所要實現的功能入手。
功能:查出選修了全部課程的學信息。那麼SQL在查詢數據的時候的遍歷每一個學生信息。判斷該學生是否滿足條件。
1
如果存在這么一條Course記錄A(暫命名為A),
則不選擇該學生。否則該學生就被查詢出來
2
那麼記錄A,是怎麼查出來的呢?A查出的條件是:不存在SC記錄B,只要不存在B,就可查出A
3
那麼B記錄是什麼?B記錄是選課信息表,根據學號和課程號可查出記錄B
如果B為空(該學生有沒有選的課程)也就是不存在,則A就有一條記錄,根據規則2可知:因為有A,所以該學生信息將不被輸出。
如果在SC中每一個課程編號和該學生編號為條件都能夠查出一條記錄B(也就是該學生選修了全部課程),所以A記錄不存在,則輸出該學生的信息。
也就是在選課表中,如果學生選了全部課程(也就是滿足SELECT
*
FROM
SC
WHERE
Sno=
Student.Sno
AND
Cno=
Course.Cno)始終存在,當然,課程編號是任意的)。那麼就輸出該學生的信息。你不要為理解這條SQL而忘記了它本身是要做什麼.
帶著SQL的目的(要實現的功能)去理解就好了。

B. SQL查詢選修了全部課程的學生姓名

分析原因如下:

第一問:兩個NOT EXISTS表示雙重否定:沒有一個選了課的學生沒有選course表裡的課程

select sname from student where not exists /*沒有一個學生滿足以下條件*/

(select * from course where not exists /*什麼條件呢?沒有選過Course表裡的課*/

(select * from sc where sno =student.sno /*這里兩個=分別指對應的關系,表示選

過課並且是Course里and cno=course.cno) 的課,只不過用not exists否定掉了*/

第二問:其實和NOT IN 是一個意思 exists只返回true 或false 這里not exists里的內容 其實就 是指學生選過的課程,再用NOT EXISTS否定了,就變成了沒有選

C. SQL資料庫中查詢選修了所有課程的學生的學號和姓名及選修門數

所有離開了數據結構(表結構)的SQL語句都是白搭!
先假設數據結構為
學生表(學號 主鍵或設有唯一索引,姓名,性別)
課程表(課程號 主鍵或設有唯一索引,課程名)
選課表(課程號,學號)-- 欄位「課程號」和「學號"設有雙欄位唯一索引
查詢出選修了所有課程的學生的學號、姓名和選修門數:
select a.學號,b.姓名,a.cnt as 選修門數 from
(select 學號,count(1) as as cnt from 選課表 group by 學號
having count(1)=(select count(1) from 課程表)) a,
學生表 b where a.學號=b.學號;

D. 用SQL查詢同時選修了1號課和2號課的學生學號

工具/材料:以Management Studio為例。

1、首先在桌面上,點擊「Management Studio」圖標。

E. 用SQL語句查詢選修了課程的學員人數

SC表裡應該有個XKLB欄位,看這門課是否選修還是必修,因為有的課程對A來說是必修的,而對B來說就是選修,
SELECT COUNT(DISTINCT SNO) FROM SC WHERE XKLB='選修';

F. 用sql語句查詢選修了3門及以上課程的學生學號,姓名,選修的課程數

SELECT學號FROM選課表GROUPBY學號HAVINGCOUNT(*)>=3

G. SQL語句查詢選了其所在系開設的所有課程的學生姓名

思路:1. 查詢出每個系有多少課程 2. 查出學生選了對應系的課程數量 3,比對前面的數量,如相等,表示選了所有的課程

select distinnct b. student_name from
(select dept, count(course_no) as c_qty from course c group by dept) a,
( select s.name as student_name, s.dept, count(course_no) as c_qty from student s, c_s cs, course c where s.id=cs.student_id and s.dept=c.dept group by cs.student_name, s.dept ) b
where a.c_qty=b.c_qty and a.dept=b.dept

按上面的SQL試一下,應該是可行的。SQL還有優化空間的...