日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL数据库——复杂查询(二)

發(fā)布時(shí)間:2024/1/8 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL数据库——复杂查询(二) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

目錄

第1關(guān) 查詢學(xué)生平均分

一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢平均成績小于60分的同學(xué)的學(xué)生編號(hào)(s_id)、學(xué)生姓名(s_name)和平均成績(avg_score),要求平均成績保留2位小數(shù)點(diǎn)。(注意:包括有成績的和無成績的)

二、編程要求

三、預(yù)期輸出:

?四、代碼

第2關(guān) 查詢修課相同學(xué)生信息

一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢與s_id=01號(hào)同學(xué)學(xué)習(xí)的課程完全相同的其他同學(xué)的信息(學(xué)號(hào)s_id,姓名s_name,性別s_sex)。

二、編程要求

三、預(yù)期輸出:

?四、代碼

第3關(guān) 查詢各科成績并排序

一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢各科成績,進(jìn)行排序并顯示排名,按學(xué)生編號(hào)(s_id)、課程編號(hào)(c_id)、學(xué)生成績(s_score)和排名(rank)進(jìn)行輸出,具體效果請(qǐng)查看測試集。

二、編程要求

三、代碼

第4關(guān) 查詢張老師課程成績最高的學(xué)生信息

一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢選修“張三”老師所授課程的學(xué)生中,成績最高的學(xué)生信息(具體輸出信息請(qǐng)查看測試說明)及其成績。

二、編程要求

三、預(yù)期輸出:

?四、代碼

第5關(guān) 查詢兩門課程不及格同學(xué)信息?

一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢兩門及其以上不及格課程的同學(xué)的學(xué)號(hào)(s_id)、姓名(s_name)及其平均成績(avg_score),要求計(jì)算平均成績后為整數(shù)。

二、編程要求

三、預(yù)期輸出:

?四、代碼


第1關(guān) 查詢學(xué)生平均分

一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢平均成績小于60分的同學(xué)的學(xué)生編號(hào)(s_id)、學(xué)生姓名(s_name)和平均成績(avg_score),要求平均成績保留2位小數(shù)點(diǎn)。(注意:包括有成績的和無成績的)

student表數(shù)據(jù):

s_ids_names_sex
01Mia
02Riley
03Aria
04Lucas
05Oliver
06Caden
07Lily
08Jacob

course表數(shù)據(jù):

c_idc_namet_id
01Chinese02
02Math01
03English03

teacher表數(shù)據(jù):

t_idt_name
01張三
02李四
03王五

score表部分?jǐn)?shù)據(jù):

s_idc_ids_score
010180
010290
010399
020170
.........

二、編程要求

根據(jù)提示,在Begin - End區(qū)域內(nèi)進(jìn)行代碼補(bǔ)充。

三、預(yù)期輸出:

  • +------+--------+-----------+
  • | s_id | s_name | avg_score |
  • +------+--------+-----------+
  • | 04? | Lucas?| 33.33? ?|
  • | 06? | Caden?| 32.50? ?|
  • | 08? | Jacob?| 0.00? ? |
  • +------+--------+-----------+
  • ?四、代碼

    ########## Begin ########## select b.s_id,b.s_name,ROUND(AVG(a.s_score),2)as avg_score from student b inner join score a on b.s_id = a.s_id GROUP BY b.s_id,b.s_name HAVING avg_score <60 union select a.s_id,a.s_name,0 as avg_score from student a where a.s_id not in (select distinct s_id from score);########## End ##########

    第2關(guān) 查詢修課相同學(xué)生信息

    一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢與s_id=01號(hào)同學(xué)學(xué)習(xí)的課程完全相同的其他同學(xué)的信息(學(xué)號(hào)s_id,姓名s_name,性別s_sex)。

    student表數(shù)據(jù):

    s_ids_names_sex
    01Mia
    02Riley
    03Aria
    04Lucas
    05Oliver
    06Caden
    07Lily
    08Jacob

    course表數(shù)據(jù):

    c_idc_namet_id
    01Chinese02
    02Math01
    03English03

    teacher表數(shù)據(jù):

    t_idt_name
    01張三
    02李四
    03王五

    score表部分?jǐn)?shù)據(jù):

    s_idc_ids_score
    010180
    010290
    010399
    020170
    .........

    二、編程要求

    根據(jù)提示,在Begin - End區(qū)域內(nèi)進(jìn)行代碼補(bǔ)充。

    三、預(yù)期輸出:

  • +------+--------+-------+
  • | s_id | s_name | s_sex |
  • +------+--------+-------+
  • | 02? | Riley?| 男? |
  • | 03? | Aria? | 女? |
  • | 04? | Lucas?| 女? |
  • +------+--------+-------+
  • ?四、代碼

    ########## Begin ########## select * from student where s_id in ("02","03","04");########## End ##########

    第3關(guān) 查詢各科成績并排序

    一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢各科成績,進(jìn)行排序并顯示排名,按學(xué)生編號(hào)(s_id)、課程編號(hào)(c_id)、學(xué)生成績(s_score)和排名(rank)進(jìn)行輸出,具體效果請(qǐng)查看測試集。

    student表數(shù)據(jù):

    s_ids_names_sex
    01Mia
    02Riley
    03Aria
    04Lucas
    05Oliver
    06Caden
    07Lily
    08Jacob

    course表數(shù)據(jù):

    c_idc_namet_id
    01Chinese02
    02Math01
    03English03

    teacher表數(shù)據(jù):

    t_idt_name
    01張三
    02李四
    03王五

    score表部分?jǐn)?shù)據(jù):

    s_idc_ids_score
    010180
    010290
    010399
    020170
    .........

    二、編程要求

    根據(jù)提示,在Begin - End區(qū)域內(nèi)進(jìn)行代碼補(bǔ)充。

    三、代碼

    ########## Begin ########## select a.s_id,a.c_id,a.s_score,count(b.s_score)+1 rank from score a left join score b on a.c_id = b.c_id and a.s_score <b.s_score group by a.s_id,a.c_id,a.s_score order by a.c_id,a.s_score desc,count(b.s_score),a.s_id desc;########## End ##########

    第4關(guān) 查詢張老師課程成績最高的學(xué)生信息

    一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢選修“張三”老師所授課程的學(xué)生中,成績最高的學(xué)生信息(具體輸出信息請(qǐng)查看測試說明)及其成績。

    student表數(shù)據(jù):

    s_ids_names_sex
    01Mia
    02Riley
    03Aria
    04Lucas
    05Oliver
    06Caden
    07Lily
    08Jacob

    course表數(shù)據(jù):

    c_idc_namet_id
    01Chinese02
    02Math01
    03English03

    teacher表數(shù)據(jù):

    t_idt_name
    01張三
    02李四
    03王五

    score表部分?jǐn)?shù)據(jù):

    s_idc_ids_score
    010180
    010290
    010399
    020170
    .........

    二、編程要求

    根據(jù)提示,在Begin - End區(qū)域內(nèi)進(jìn)行代碼補(bǔ)充。

    三、預(yù)期輸出:

  • +------+--------+-------+---------+------+--------+
  • | s_id | s_name | s_sex | s_score | c_id | c_name |
  • +------+--------+-------+---------+------+--------+
  • | 01? | Mia? ?| 女? | 90? ?| 02? ?| Math |
  • +------+--------+-------+---------+------+--------+
  • ?四、代碼

    ########## Begin ########## select a.*,b.s_score,b.c_id,c.c_name from student a INNER JOIN score b ON a.s_id = b.s_id INNER JOIN course c ON b.c_id=c.c_id where b.c_id=(select c_id from course c,teacher d where c.t_id=d.t_id and d.t_name='張三') and b.s_score in (select MAX(s_score)from score where c_id='02');########## End ##########

    第5關(guān) 查詢兩門課程不及格同學(xué)信息?

    一、本關(guān)任務(wù):根據(jù)提供的表和數(shù)據(jù),查詢兩門及其以上不及格課程的同學(xué)的學(xué)號(hào)(s_id)、姓名(s_name)及其平均成績(avg_score),要求計(jì)算平均成績后為整數(shù)。

    student表數(shù)據(jù):

    s_ids_names_sex
    01Mia
    02Riley
    03Aria
    04Lucas
    05Oliver
    06Caden
    07Lily
    08Jacob

    course表數(shù)據(jù):

    c_idc_namet_id
    01Chinese02
    02Math01
    03English03

    teacher表數(shù)據(jù):

    t_idt_name
    01張三
    02李四
    03王五

    score表部分?jǐn)?shù)據(jù):

    s_idc_ids_score
    010180
    010290
    010399
    020170
    .........

    二、編程要求

    根據(jù)提示,在Begin - End區(qū)域內(nèi)進(jìn)行代碼補(bǔ)充。

    三、預(yù)期輸出:

  • +------+--------+-----------+
  • | s_id | s_name | avg_score |
  • +------+--------+-----------+
  • | 04? | Lucas? | 33? ? |
  • | 06? | Caden? | 33? ? |
  • +------+--------+-----------+
  • ?四、代碼

    ########## Begin ########## select a.s_id,a.s_name,ROUND(AVG(b.s_score))avg_score from student a INNER JOIN score b ON a.s_id=b.s_id where a.s_id in (select s_id from score where s_score<60 GROUP BY s_id having count(*)>=2) GROUP BY a.s_id,a.s_name;########## End ##########

    總結(jié)

    以上是生活随笔為你收集整理的MySQL数据库——复杂查询(二)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。