當前位置:首頁 » 成績查詢 » 學生老師課程成績查詢

學生老師課程成績查詢

發布時間: 2021-02-12 19:09:04

❶ PL SQL查詢「張旭「教師任課的學生成績

分開JOIN試試
----------
SELECT A.SNO
版 ,A.DEGREE
FROM SCORE A
JOIN TEACHER B ON B.TNO=C.TNO
JOIN COURSE C ON A.CNO=C.CNO
WHERE B.TNAME='張旭權'

❷ Student 學生表 ,Course 課程表 ,SC成績表 ,Teacher 教師表,sql操作運用

建表語句

CREATE TABLE student
(
s# INT,
sname nvarchar(32),
sage INT,
ssex nvarchar(8)
)

CREATE TABLE course
(
c# INT,
cname nvarchar(32),
t# INT
)

CREATE TABLE sc
(
s# INT,
c# INT,
score INT
)

CREATE TABLE teacher
(
t# INT,
tname nvarchar(16)
)

插入測試數據語句

insert into Student select 1,N'劉一',18,N'男' union all
select 2,N'錢二',19,N'女' union all
select 3,N'張三',17,N'男' union all
select 4,N'李四',18,N'女' union all
select 5,N'王五',17,N'男' union all
select 6,N'趙六',19,N'女'

insert into Teacher select 1,N'葉平' union all
select 2,N'賀高' union all
select 3,N'楊艷' union all
select 4,N'周磊'

insert into Course select 1,N'語文',1 union all
select 2,N'數學',2 union all
select 3,N'英語',3 union all
select 4,N'物理',4

insert into SC
select 1,1,56 union all
select 1,2,78 union all
select 1,3,67 union all
select 1,4,58 union all
select 2,1,79 union all
select 2,2,81 union all
select 2,3,92 union all
select 2,4,68 union all
select 3,1,91 union all
select 3,2,47 union all
select 3,3,88 union all
select 3,4,56 union all
select 4,2,88 union all
select 4,3,90 union all
select 4,4,93 union all
select 5,1,46 union all
select 5,3,78 union all
select 5,4,53 union all
select 6,1,35 union all
select 6,2,68 union all
select 6,4,71

問題

問題: 1、查詢「001」課程比「002」課程成績高的所有學生的學號; select a.S# from (select s#,score from SC where C#='001') a,(select s#,score from SC where C#='002') b where a.score>b.score and a.s#=b.s#; 2、查詢平均成績大於60分的同學的學號和平均成績; select S#,avg(score) from sc group by S# having avg(score) >60; 3、查詢所有同學的學號、姓名、選課數、總成績; select Student.S#,Student.Sname,count(SC.C#),sum(score) from Student left Outer join SC on Student.S#=SC.S# group by Student.S#,Sname 4、查詢姓「李」的老師的個數; select count(distinct(Tname)) from Teacher where Tname like '李%'; 5、查詢沒學過「葉平」老師課的同學的學號、姓名; select Student.S#,Student.Sname from Student where S# not in (select distinct( SC.S#) from SC,Course,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='葉平'); 6、查詢學過「001」並且也學過編號「002」課程的同學的學號、姓名; select Student.S#,Student.Sname from Student,SC where Student.S#=SC.S# and SC.C#='001'and exists( Select * from SC as SC_2 where SC_2.S#=SC.S# and SC_2.C#='002'); 7、查詢學過「葉平」老師所教的所有課的同學的學號、姓名; select S#,Sname from Student where S# in (select S# from SC ,Course ,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='葉平' group by S# having count(SC.C#)=(select count(C#) from Course,Teacher where Teacher.T#=Course.T# and Tname='葉平')); 8、查詢課程編號「002」的成績比課程編號「001」課程低的所有同學的學號、姓名; Select S#,Sname from (select Student.S#,Student.Sname,score ,(select score from SC SC_2 where SC_2.S#=Student.S# and SC_2.C#='002') score2 from Student,SC where Student.S#=SC.S# and C#='001') S_2 where score2 <score; 9、查詢所有課程成績小於60分的同學的學號、姓名; select S#,Sname from Student where S# not in (select S.S# from Student AS S,SC where S.S#=SC.S# and score>60); 10、查詢沒有學全所有課的同學的學號、姓名; select Student.S#,Student.Sname from Student,SC where Student.S#=SC.S# group by Student.S#,Student.Sname having count(C#) <(select count(C#) from Course); 11、查詢至少有一門課與學號為「1001」的同學所學相同的同學的學號和姓名; select distinct S#,Sname from Student,SC where Student.S#=SC.S# and SC.C# in (select C# from SC where S#='1001'); 12、查詢至少學過學號為「001」同學所有一門課的其他同學學號和姓名; select distinct SC.S#,Sname from Student,SC where Student.S#=SC.S# and C# in (select C# from SC where S#='001'); 13、把「SC」表中「葉平」老師教的課的成績都更改為此課程的平均成績; update SC set score=(select avg(SC_2.score) from SC SC_2 where SC_2.C#=SC.C# ) from Course,Teacher where Course.C#=SC.C# and Course.T#=Teacher.T# and Teacher.Tname='葉平'); 14、查詢和「1002」號的同學學習的課程完全相同的其他同學學號和姓名; select S# from SC where C# in (select C# from SC where S#='1002') group by S# having count(*)=(select count(*) from SC where S#='1002'); 15、刪除學習「葉平」老師課的SC表記錄; Delect SC from course ,Teacher where Course.C#=SC.C# and Course.T#= Teacher.T# and Tname='葉平'; 16、向SC表中插入一些記錄,這些記錄要求符合以下條件:沒有上過編號「003」課程的同學學號、2、 號課的平均成績; Insert SC select S#,'002',(Select avg(score) from SC where C#='002') from Student where S# not in (Select S# from SC where C#='002'); 17、按平均成績從高到低顯示所有學生的「資料庫」、「企業管理」、「英語」三門的課程成績,按如下形式顯示: 學生ID,,資料庫,企業管理,英語,有效課程數,有效平均分 SELECT S# as 學生ID ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='004') AS 資料庫 ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='001') AS 企業管理 ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='006') AS 英語 ,COUNT(*) AS 有效課程數, AVG(t.score) AS 平均成績 FROM SC AS t GROUP BY S# ORDER BY avg(t.score) 18、查詢各科成績最高和最低的分:以如下形式顯示:課程ID,最高分,最低分 SELECT L.C# As 課程ID,L.score AS 最高分,R.score AS 最低分 FROM SC L ,SC AS R WHERE L.C# = R.C# and L.score = (SELECT MAX(IL.score) FROM SC AS IL,Student AS IM WHERE L.C# = IL.C# and IM.S#=IL.S# GROUP BY IL.C#) AND R.Score = (SELECT MIN(IR.score) FROM SC AS IR WHERE R.C# = IR.C# GROUP BY IR.C# );
自己寫的:select c# ,max(score)as 最高分 ,min(score) as 最低分 from dbo.sc group by c# 19、按各科平均成績從低到高和及格率的百分數從高到低順序 SELECT t.C# AS 課程號,max(course.Cname)AS 課程名,isnull(AVG(score),0) AS 平均成績 ,100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) AS 及格百分數 FROM SC T,Course where t.C#=course.C# GROUP BY t.C# ORDER BY 100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) DESC 20、查詢如下課程平均成績和及格率的百分數(用"1行"顯示): 企業管理(001),馬克思(002),OO&UML (003),資料庫(004) SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS 企業管理平均分 ,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '001' THEN 1 ELSE 0 END) AS 企業管理及格百分數 ,SUM(CASE WHEN C# = '002' THEN score ELSE 0 END)/SUM(CASE C# WHEN '002' THEN 1 ELSE 0 END) AS 馬克思平均分 ,100 * SUM(CASE WHEN C# = '002' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '002' THEN 1 ELSE 0 END) AS 馬克思及格百分數 ,SUM(CASE WHEN C# = '003' THEN score ELSE 0 END)/SUM(CASE C# WHEN '003' THEN 1 ELSE 0 END) AS UML平均分 ,100 * SUM(CASE WHEN C# = '003' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '003' THEN 1 ELSE 0 END) AS UML及格百分數 ,SUM(CASE WHEN C# = '004' THEN score ELSE 0 END)/SUM(CASE C# WHEN '004' THEN 1 ELSE 0 END) AS 資料庫平均分 ,100 * SUM(CASE WHEN C# = '004' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '004' THEN 1 ELSE 0 END) AS 資料庫及格百分數 FROM SC

21、查詢不同老師所教不同課程平均分從高到低顯示
SELECT max(Z.T#) AS 教師ID,MAX(Z.Tname) AS 教師姓名,C.C# AS 課程ID,MAX(C.Cname) AS 課程名稱,AVG(Score) AS 平均成績
FROM SC AS T,Course AS C ,Teacher AS Z
where T.C#=C.C# and C.T#=Z.T#
GROUP BY C.C#
ORDER BY AVG(Score) DESC
22、查詢如下課程成績第 3 名到第 6 名的學生成績單:企業管理(001),馬克思(002),UML (003),資料庫(004)
[學生ID],[學生姓名],企業管理,馬克思,UML,資料庫,平均成績
SELECT DISTINCT top 3
SC.S# As 學生學號,
Student.Sname AS 學生姓名 ,
T1.score AS 企業管理,
T2.score AS 馬克思,
T3.score AS UML,
T4.score AS 資料庫,
ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) as 總分
FROM Student,SC LEFT JOIN SC AS T1
ON SC.S# = T1.S# AND T1.C# = '001'
LEFT JOIN SC AS T2
ON SC.S# = T2.S# AND T2.C# = '002'
LEFT JOIN SC AS T3
ON SC.S# = T3.S# AND T3.C# = '003'
LEFT JOIN SC AS T4
ON SC.S# = T4.S# AND T4.C# = '004'
WHERE student.S#=SC.S# and
ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)
NOT IN
(SELECT
DISTINCT
TOP 15 WITH TIES
ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)
FROM sc
LEFT JOIN sc AS T1
ON sc.S# = T1.S# AND T1.C# = 'k1'
LEFT JOIN sc AS T2
ON sc.S# = T2.S# AND T2.C# = 'k2'
LEFT JOIN sc AS T3
ON sc.S# = T3.S# AND T3.C# = 'k3'
LEFT JOIN sc AS T4
ON sc.S# = T4.S# AND T4.C# = 'k4'
ORDER BY ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) DESC);

23、統計列印各科成績,各分數段人數:課程ID,課程名稱,[100-85],[85-70],[70-60],[ <60]
SELECT SC.C# as 課程ID, Cname as 課程名稱
,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85]
,SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70]
,SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60]
,SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]
FROM SC,Course
where SC.C#=Course.C#
GROUP BY SC.C#,Cname;

24、查詢學生平均成績及其名次
SELECT 1+(SELECT COUNT( distinct 平均成績)
FROM (SELECT S#,AVG(score) AS 平均成績
FROM SC
GROUP BY S#
) AS T1
WHERE 平均成績 > T2.平均成績) as 名次,
S# as 學生學號,平均成績
FROM (SELECT S#,AVG(score) 平均成績
FROM SC
GROUP BY S#
) AS T2
ORDER BY 平均成績 desc;

原文地址:http://www.cnblogs.com/qixuejia/p/3637735.html

❸ 求個學生成績管理信息系統 就學生和教師 學生課程查詢 修...

求個學生成績管理信息系統 就學生和教師 學生課程查詢 修...
u can download the related project example from many web site, ex.CSDN. Good luck.

汗馬絕塵安外振中標青史 錦羊開泰富民清政展新篇 春滿人間

❹ access中如何查詢教師所教成績

三張表數據結構有嚴重問題
表1沒有問題
表二中 所教課程一行只能寫一版個值,如果一個教師教多權門課,則錄入多行
表3 欄位應該是 學號 姓名 班級
表4 應該是成績表 欄位是 學號 課程編號 成績

然後就可以用鏈接表查詢出任何想要的東西了

❺ 學生表:學號,姓名,性別 課程表:編號,課程 成績表:標號,學生學號,課程編號,成績 1.查詢沒有

1-1最終查詢的是學生姓名,所以select後面寫學生姓名
學生姓名在學生表中,所以from後面寫學生表
條件是沒有上過李明老師課,需要到成績表中查詢最終可以查到學生的學號
select 姓名
from 學生表
where 學號 in(沒上過李明老師課的學號)
1-2在成績表中查詢沒上過李明老師課的學號
select 學號
from 成績表
where 課程編號 in(李明老師課的課程編號)
1-3在課程表中查詢李明老師課的課程編號
select 課程編號
from 課程表
where 開課教師 = '李明'
所以第一個問題 你這個資料庫少個列啊,沒有教師的事啊
select 姓名
from 學生表
where 學號 in
(

select 學號
from 成績表
where 課程編號 in
(

select 課程編號
from 課程表
where 開課教師 = '李明'
)
)
2.
select 學生姓名,avg(成績)
from 學生表 inner join 成績表
on 學生表.學號 = 成績表.學號
where 成績<60
group by 學生姓名
having count(*)>=2

❻ sql 查詢學生姓名為XXX(同學自己設定)所學課程中成績最好的課程名和相關的教師姓名

accept "請輸入姓名:" to xmselect 學號,課程號,工號,max(成績) as 最高分版 from jiaoxue group by 學號,課程號 into table jiaoxue1select student.姓名權 as 學生姓名,課程名,teacher.姓名 as 教師姓名 from student,teacher,course,jiaoxue1 where 姓名=xm and student.學號=jiaoxue1.學號 and teacher.工號=jiaoxue1.工號 and course.課程號=jiaoxue1.課程號

❼ 求個學生成績管理信息系統 就學生和教師 學生課程查詢 修改什麼的最基本的那種, 謝謝啊 344176774


you can download the related project example from many web site, ex.CSDN. Good luck.

❽ 學生成績查詢系統如何編寫

隨著教育部禁止對考試成績進行公開排名及公開公布成績後,學校一般都選擇不再公開公布考試專成績屬,但是考試是檢測學生一段時間的學習狀態的主要手段,家長和老師也需要通過考試成績來對孩子們近期的學習進行查缺補漏,所以考試是不可避免的!但是對於公布成績,很多老師不知道怎樣有效發布,其實老師們可以用易查分做一個自主查詢系統,避免因為公布成績而帶來的各種問題,因為都是自己查自己的,所以私密度極高!用易查分發布查詢系統也很方便,差不多3分鍾左右就可以製作好一個查詢系統!值得老師們嘗試!!!

❾ 數據表 學生表,老師表,課程表,成績表 S(S#,Sname)T(T#,Tname,age)C(C#,Cname,T#) SC(S#,c#,sore)

1. select 學號,avg(成績復) from 表名 where avg(成績)>60 group by 學號
2、制update 表名 set 名字=』王文『 where 課程=『地理』
3和4 我不寫了 我不清楚欄位是什麼 。這個都應該是操作多張表 你根據他們的關聯性去寫吧 關聯性 有找主外鍵用主外鍵作為條件,沒有就找關聯性 相同的欄位,進行修改、刪除操作

❿ 有四張表:Student 學生表 ,Course 課程表 ,SC成績表 ,Teacher 教師表,求SQL語句

把表結構發來,我給你寫

熱點內容
武漢大學學生會輔導員寄語 發布:2021-03-16 21:44:16 瀏覽:612
七年級學生作文輔導學案 發布:2021-03-16 21:42:09 瀏覽:1
不屑弟高考成績 發布:2021-03-16 21:40:59 瀏覽:754
大學畢業證會有成績單 發布:2021-03-16 21:40:07 瀏覽:756
2017信陽學院輔導員招聘名單 發布:2021-03-16 21:40:02 瀏覽:800
查詢重慶2018中考成績查詢 發布:2021-03-16 21:39:58 瀏覽:21
結業考試成績怎麼查詢 發布:2021-03-16 21:28:40 瀏覽:679
14中醫醫師資格筆試考試成績查分 發布:2021-03-16 21:28:39 瀏覽:655
名著賞析課程標准 發布:2021-03-16 21:27:57 瀏覽:881
北京大學商業領袖高端培訓課程 發布:2021-03-16 21:27:41 瀏覽:919