玩家必看科普!麻豆人人妻人人妻人人片AV,欧美老妇交乱视频在线观看,久久综合九色综合久99_知乎
<ruby id="fgcka"></ruby>
  • <progress id="fgcka"></progress>
    <tbody id="fgcka"></tbody>
    <dd id="fgcka"></dd>

    1. <dd id="fgcka"></dd>

      <em id="fgcka"></em>
        1. 系統城裝機大師 - 固鎮縣祥瑞電腦科技銷售部宣傳站!

          當前位置:首頁 > 數據庫 > MsSql > 詳細頁面

          MySQL三表聯合查詢操作舉例在mysql查詢語句中,為了實現查詢到某些信息,我們會用到多表的聯合查詢,下面這篇文章主要給大家介紹了關于MySQL三表聯合查詢操作的相關資料,文中通過實例代碼介紹的非常

          時間:2023-03-06來源:系統城裝機大師作者:佚名

          一、題目概述

          給定三張表(學生表、科目表、成績表),查出各科成績最高的學生的信息(學號、姓名、科目名稱、成績)。三張表下所示。

          圖片表

          科目表

          成績表

          二、查詢思路

          1.查詢出各科的最高成績

          select max(s.`Score`) as MaxScore from score s group by s.`SubjectId`
          

          2.查詢出各科的最高成績及對應的科目和學生編號(關鍵步驟)

          此處通過子查詢完成。根據步驟1中查出的最高成績,再查成績表中成績等于最高成績且科目相對應的記錄

          select b.* from (
             select max(s.`Score`) as MaxScore,s.`SubjectId` as SubId from score s group by s.`SubjectId`)
             f,score b where b.`SubjectId` = f.SubId and b.`Score` = f.MaxScore
          

          該步驟的結果如下所示:

          最高科目的學生信息

          3. 查詢出各科的最高成績及對應的科目名稱和學生編號

          步驟2只涉及了成績表,由于該表不含成績名稱,需要與科目表進行聯表查詢

          SELECT b.`StudentId`,f.SubName,b.`Score` FROM (
             SELECT MAX(s.`Score`) AS MaxScore,s.`SubjectId` AS SubId,sub.`Name` AS SubName
             FROM score s LEFT JOIN SUBJECT AS sub ON s.`SubjectId` = sub.`SubjectNo` 
             GROUP BY s.`SubjectId`)f,score b WHERE b.`SubjectId` = f.SubId AND b.`Score` = f.MaxScore
          

          該步驟的結果如下所示:

          4. 查詢出各科的最高成績及對應的科目名稱和學生姓名

          同理,再與學生表進行一次聯表查詢,查出學生姓名

          SELECT stu.Name,t.* FROM 
              (SELECT b.`StudentId` AS Sid,f.SubName AS SubName,b.`Score` AS Score FROM 
                   (SELECT MAX(s.`Score`) AS MaxScore,sub.`SubjectNo` AS SubNo,sub.`Name` AS SubName 
                    FROM score s LEFT JOIN SUBJECT AS sub ON s.`SubjectId` = sub.`SubjectNo` GROUP BY sub.`SubjectNo`) 
              f,score b WHERE b.`StudentId` = f.SubNo AND b.`Score` = f.MaxScore) 
          t LEFT JOIN student stu ON stu.StudentNo = t.Sid ORDER BY t.Score
          

          最終結果如下:

          最終結果

          三、錯誤總結

          完成本題中遇到的一些錯誤,簡單總結以下

          對group by的結果理解有問題。下面的SQL查詢嘗試查出最高成績對應的學生Id,

          SELECT s.`StudentId` AS Sid,
          MAX(s.`Score`) AS MaxScore,sub.`Name` AS SubName FROM score s LEFT JOIN SUBJECT AS sub ON s.`SubjectId` = 
          sub.`SubjectNo` GROUP BY s.`SubjectId`
          

          實際上SQL查出的學生Id都是3,即對應最高成績的Id是錯誤的。原因在于group by只是在select的查詢結果基礎上根據分組指定的關鍵字進行分組,并將分組后的若干記錄的中第一條進行展示,此處正好語數外分組的第一條記錄的學生Id都是3,因此是錯誤的??偨Y來說group by 只進行了分組,記錄中的其他字段需要另外想辦法查詢。

          附:sql 三個表聯合查詢(三表左聯查詢)

          關于在一個表中顯示三個數據庫表字段的查詢。

          首先要找的三個表中字段的對應關系,以哪一張表為主表(其他表字段增添這個主表上)作為顯示頁面上。

          上代碼

          查詢主表:csb_accessories_bjgh的全部,csb_accessories_bjqd表,csb_asset_directory表,的aname,atypes,/assetname,assettypes的字段。

          關系:csb_accessories_bjgh.accessoriesid = csb_accessories_bjqd.accessoriesid

           

          以及 csb_accessories_bjgh.assetid = csb_asset_directory.assetid

          這是sql代碼

          1
          2
          3
          4
          5
          6
          7
          8
          9
          10
          SELECT
          csb_accessories_bjgh.*,
          csb_accessories_bjqd.aname,
          csb_accessories_bjqd.atypes,
          csb_asset_directory.assetname,
          csb_asset_directory.assettypes
          FROM
          (( csb_accessories_bjgh LEFT JOIN csb_accessories_bjqd ON csb_accessories_bjgh.accessoriesid = csb_accessories_bjqd.accessoriesid ) LEFT JOIN csb_asset_directory ON csb_accessories_bjgh.assetid = csb_asset_directory.assetid )
          WHERE
          csb_accessories_bjgh.id IS NOT NULL

          總結

          到此這篇關于MySQL三表聯合查詢操作的文章就介紹到這了!

          分享到:

          相關信息

          • mdf文件無法復制解決方法

            很多用戶在電腦上操作的時候都遇到過想要復制mdf文件卻發現無法復制的情況吧,那么遇到了這個問題該如何去解決呢?今天就為大家帶來了解決的方法一起看看吧。...

            2022-11-11

          • mdf文件轉iso詳細方法

            iso是目前非常流行的通用光盤映像文件格式,很多的用戶都想把mdf格式的文件轉換成iso格式但苦于不會操作,下面就為大家帶來詳細的操作方法一起看看吧。...

            2022-11-11

          系統教程欄目

          欄目熱門教程

          人氣教程排行

          站長推薦

          熱門系統下載

          玩家必看科普!麻豆人人妻人人妻人人片AV,欧美老妇交乱视频在线观看,久久综合九色综合久99_知乎 人人玩人人添人人澡超碰偷拍 青春娱乐视频精品分类官网2 最好最新高清中文字幕 91国自产拍最新2018 欧美精品一区二区三区不卡网 深夜你懂得我的意思2021 宿舍NP乖把腿张开H 网恋奔现一天被要几次 为什么我越叫他越快 学渣各种各样的PLAY 英语课代表下面好软小说 亚洲国产综合在线区尤物 FREE性丰满HD性欧美 我年轻漂亮的继坶BD 最近中文字幕完整免费视频 啦啦啦免费视频卡一卡二 青柠视频在线观看大全 在线天堂WWW在线资源 亚洲国产日本韩国欧美MV 天天学习|久久久久久久精品国产亚洲87 国产K频道分享系统进入口 三个嘴都吃满了还塞满了 JAPONENSIS老师学生JAVAHBB 亚洲精品1卡2卡3卡4卡 樱花草在线社区WWW韩国 好涨水快流出来了快吃动视频 久久AV无码精品人妻出轨