accp8.0轉換教材第3章MySQL高級查詢(一)理解與練習

来源:http://www.cnblogs.com/a782126844/archive/2017/06/29/7095290.html
-Advertisement-
Play Games

一.單詞部分 ①constraint約束②foreign外鍵③references參考 ④subquery子查詢⑤inner內部的⑥join連接 二.預習部分 1.修改表SQL語句的關鍵字是什麼 RENAME 修改表名CHANGE修改欄位 2.哪個關鍵字可以按指定行數返回查詢結果集 LIMIT 3. ...


一.單詞部分

①constraint約束②foreign外鍵③references參考

④subquery子查詢⑤inner內部的⑥join連接

二.預習部分

1.修改表SQL語句的關鍵字是什麼

RENAME 修改表名CHANGE修改欄位

2.哪個關鍵字可以按指定行數返回查詢結果集

LIMIT

3.表連接都可以用子查詢替換嗎

可以

三.練習部分

1. 創建數據表,並實現對錶的修改操作

#上機1
USE test;
CREATE TABLE person(
number INT(4) AUTO_INCREMENT PRIMARY KEY,
`name` VARCHAR(50) NOT NULL,
sex CHAR(2),
bornDate DATETIME
);
ALTER TABLE person RENAME tb_person;
ALTER TABLE tb_person DROP `bornDate`;
ALTER TABLE tb_person ADD bornDate DATETIME;
ALTER TABLE tb_person CHANGE number id BIGINT;

2.使用SQL語句為myschool資料庫中的result表添加約束

#上機2
USE myschool;
ALTER TABLE result ADD CONSTRAINT re PRIMARY KEY result(`studentNo`,`subjectNo`,`exameDate`);
ALTER TABLE result ADD CONSTRAINT fk_result_student FOREIGN KEY (studentNo) REFERENCES student (studentNo);

3.為學生表,科目表,成績表添加數據

#上機3
USE myschool;
INSERT INTO `subject` (`subjectName`, `classHour`, `gradeID`) VALUES
('HTML', '160', '1'),
('Java OOP', '230', '2');

4.修改學生表,科目表數據

#上機4
USE myschool;
INSERT INTO `myschool`.`result` (`studentNo`, `subjectNo`, `exameDate`, `studentResult`) VALUES ('1002', '1', '2014-8-8', '78'),
('1003', '2', '2017-7-7', '98'),
('1004', '1', '2015-8-8', '78'),
('1005', '2', '2013-8-8', '78'),
('1006', '1', '2017-8-8', '66'),
('1007', '1', '2014-8-8', '55'),
('1008', '1', '2014-8-8', '13'),
('1009', '1', '2014-8-8', '89');
UPDATE student SET eamil='[email protected]',loginPwd='000' WHERE studentNo='20000';
UPDATE `subject` SET `classHour`=`classHour`-10 WHERE `classHour`>200 AND `subjectNo`=1;
DROP TABLE IF EXISTS student_grade1;
CREATE TABLE student_grade1(SELECT `studentName`,`sex`,`bornDate`,`phone` FROM student WHERE `gradeID`=1);

5.查詢學生信息(查詢2016年2月17日前五名 的學生的學號和分數)

#上機5
SELECT `studentNo`,`studentResult` FROM `result` WHERE `exameDate`<'2016-2-17' ORDER BY studentResult DESC LIMIT 5;

SELECT studentName,(YEAR(NOW())-YEAR(bornDate)) AS age,bornDate,phone FROM student
WHERE sex='女'
ORDER BY bornDate ASC
LIMIT 1,6;

SELECT YEAR(bornDate) AS nian,COUNT(studentNo) AS num FROM student GROUP BY bornDate HAVING COUNT(studentNo)>=2;

SELECT MAX(`studentResult`),MIN(`studentResult`),AVG(`studentResult`) FROM `result` WHERE `exameDate`='2016-02-17' GROUP BY `studentNo`;

6.查詢指定學生的考試成績

#上機6
SELECT MAX(`studentResult`),MIN(`studentResult`) FROM result
WHERE `exameDate`=(SELECT `exameDate` FROM `result` ORDER BY exameDate DESC LIMIT 1) AND
`subjectNo`=(SELECT `subjectNo` FROM `subject` WHERE `subjectName`='Logic Java');
#select max(exameDate) from result

7.查詢某學期開設的課程

#上機7
SELECT subjectName FROM `subject` 
WHERE subjectNo IN(SELECT subjectNo FROM `subject` 
WHERE gradeId=(SELECT gradeId FROM grade WHERE gradeName='S1'));

8.查詢某課程最近一次考試缺考的學生名單

#上機8
SELECT `studentName` FROM student WHERE `studentNo` IN(SELECT `studentNo` FROM student WHERE studentNo NOT IN(SELECT `studentNo` FROM `result`
WHERE `subjectNo`=(SELECT `subjectNo` FROM `subject` WHERE `subjectName`='HTML') AND
`exameDate`=(SELECT `exameDate` FROM `result` WHERE subjectNo=(SELECT `subjectNo` FROM `subject` WHERE `subjectName`='HTML')
ORDER BY exameDate DESC LIMIT 1)));

五.總結部分

多表聯查實現的兩種方式:

①表連接

②子查詢

歡迎提問,歡迎指錯,歡迎討論學習信息 有需要的私聊 發佈評論即可 都能回覆的

  原文在博客園有需要可以聯繫扣扣:2265682997


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MySQL 5.7 SSL連接最佳實戰 1. 背景 * 在生產環境下,安全總是無法忽視的問題,資料庫安全則是重中之重,因為所有的數據都存放在資料庫中 * 當使用非加密方式連接MySQL資料庫時,在網路中傳輸的所有信息都是明文的,可以被網路中所有人截取,敏感信息可能被泄露。在傳送敏感信息(如密碼)時, ...
  • 1.資料庫優化的目的 2.資料庫優化的方向 ...
  • 參考:http://www.cnblogs.com/WeiGe/p/4903850.html 一對多分為關聯模式和內嵌模式 內嵌與關聯什麼時候用: 存在雙向查詢則用關聯,還需用到索引。 當兩者是包含關係,並且被包含的對象不會經常的變化,並不會進行雙向查詢,被包含對象不會進行其他的關聯查 則用到內嵌模 ...
  • http://dev.mysql.com/doc/refman/5.7/en/resetting-permissions.html親測方法3,已成功重置密碼。(感謝@非常,告訴我官網就有重置方法,網上搜了一堆堆...另外,step1和2來源於http://www.2cto.com/database/ ...
  • 1、查找表中多餘的重覆記錄,重覆記錄是根據單個欄位(Id)來判斷 select * from 表 where Id in (select Id from 表 group byId having count(Id) > 1) 2、刪除表中多餘的重覆記錄,重覆記錄是根據單個欄位(Id)來判斷,只留有ro ...
  • ## ## 需求場景: 由於MySQL沒有類似於SQL SERVER那樣的系統表來存放備份記錄,且大規模的MySQL伺服器需要集中管理和查看。 伺服器出現性能問題或複製延遲時,需要先判斷是否由數據備份引起。 ## ## 第一版 按照需求,考慮到需要記錄的備份信息有備份伺服器信息、備份開始結束時間、備 ...
  • 知識點:EXISTS子查詢、NOT EXISTS子查詢、分頁查詢、UNION聯合查詢 一.單詞部分 ①exist存在②temp臨時的③district區域 ④content內容⑤temporary暫時的 二.預習部分 1.表連接都可以用子查詢替換嗎 是的 2.檢測某列是否存在某個範圍可以在子查詢中使 ...
  • 當跳轉到user頁面時,右邊的uiview是為空的,要點擊了左側的導航才能插入模板,如何在路由中設置二級視圖的預設顯示頁面呢? app.config(function($stateProvider, $urlRouterProvider) { $urlRouterProvider.when('', ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...