《實驗訓練1 在MySQL中創(chuàng)建數據庫和表》由會員分享,可在線閱讀,更多相關《實驗訓練1 在MySQL中創(chuàng)建數據庫和表(9頁珍藏版)》請在裝配圖網上搜索。
1、.實驗訓練1 在MySQL中創(chuàng)建數據庫和表請到電腦端查看實驗目的熟悉MySQL環(huán)境的使用,掌握在MySQL中創(chuàng)建數據庫和表的方法,理解MySQL支持的數據類型、數據完整性在MySQL下的表現形式,練習MySQL數據庫服務器的使用,練習CREATE TABLE,SHOW TABLES,DESCRIBE TABLE,ALTER TABLE,DROP TABLE語句的操作方法。實驗內容:【實驗1-1】MySQL的安裝與配置。參見4.1節(jié)內容,完成MySQL數據庫的安裝與配置?!緦嶒?-2】創(chuàng)建“汽車用品網上商城系統(tǒng)”數據庫。用CREATE DATABASE語句創(chuàng)建Shopping數據庫,或者通過My
2、SQL Workbench圖形化工具創(chuàng)建Shopping數據庫?!緦嶒?-3】在Shopping數據庫下,參見3.5節(jié),創(chuàng)建表3-4表3-11的八個表??梢允褂肅REATE TABLE語句,也可以用MySQL Workbench創(chuàng)建表?!緦嶒?-4】使用SHOW、DESCRIBE語句查看表。【實驗1-5】使用ALTER TABLE、RENAME TABLE語句管理表?!緦嶒?-6】使用DROP TABLE語句刪除表,也可以使用MySQL Workbench刪除表。(注意:刪除前最好對已經創(chuàng)建的表進行復制。)【實驗1-7】連接、斷開MySQL服務器,啟動、停止MySQL服務器?!緦嶒?-8】使用
3、SHOW DATABASE、USE DATABASE、DROP DATABASE語句管理“網上商城系統(tǒng)” Shopping數據庫。實驗要求:1 配合第1章第3章的理論講解,理解數據庫系統(tǒng)。2 掌握MySQL工具的使用,通過MySQL Workbench圖形化工具完成。3 每執(zhí)行一種創(chuàng)建、刪除或修改語句后,均要求通過MySQL Workbench查看執(zhí)行結果。4 將操作過程以屏幕抓圖的方式復制,形成實驗文檔。實驗訓練2:數據查詢操作請到電腦端查看實驗目的:基于實驗1創(chuàng)建的汽車用品網上商城數據庫Shopping,理解MySQL運算符、函數、謂詞,練習Select語句的操作方法。實驗內容:1.單表查
4、詢【實驗2.1】字段查詢(1)查詢商品名稱為“擋風玻璃”的商品信息。分析:商品信息存在于商品表,而且商品表中包含商品名稱此被查詢信息,因此這是只需要涉及一個表就可以完成簡單單表查詢。(2)查詢ID為1的訂單。分析:所有的訂單信息存在于訂單表中,而且訂單用戶ID也存在于此表中,因此這是只需要查詢訂單表就可以完成的查詢?!緦嶒?.2】多條件查詢查詢所有促銷的價格小于1000的商品信息。分析:此查詢過程包含兩個條件,第一個是是否促銷,第二個是價格,在商品表中均有此信息,因此這是一個多重條件的查詢。【實驗2.3】DISTINCT(1)查詢所有對商品ID為1的商品發(fā)表過評論的用戶ID。分析:條件和查詢對
5、象存在于評論表中,對此商品發(fā)表過評論的用戶不止一個,而且一個用戶可以對此商品發(fā)表多個評論,因此,結果需要進行去重,這里使用DISTINCT實現。(2)查詢此汽車用品網上商城會員的創(chuàng)建時間段,1年為一段。分析:通過用戶表可以完成查詢,每年可能包含多個會員,如果把此表中的創(chuàng)建年份都列出來會有重復,因此使用DISTINCT去重。【實驗2.4】ORDER BY(1)查詢類別ID為1的所有商品,結果按照商品ID降序排列。分析:從商品表中可以查詢出所有類別ID為1的商品信息,結果按照商品ID的降序排列,因此使用ORDER BY語句,降序使用DESC關鍵字。(2)查詢今年新增的所有會員,結果按照用戶名字排序
6、。分析:在用戶表中可以完成查詢,創(chuàng)建日期條件設置為今年,此處使用語句ORDER BY。【實驗2.5】GROUP BY(1)查詢每個用戶的消費總金額(所有訂單)。分析:訂單表中包含每個訂單的訂單總價和用戶ID?,F在需要將每個用戶的所有訂單提取出來分為一類,通過SUM()函數取得總金額。此處使用GROUP BY語句和SUM()函數。(2)查詢類別價格一樣的各種商品數量總和。分析:此查詢中需要對商品進行分類,分類依據是同類別和價格,這是“多列分組”,較上一個例子更為復雜。2.聚合函數查詢【實驗2.6】COUNT()(1)查詢類別的數量。分析:此查詢利用COUNT()函數,返回指定列中值的數目,此處指
7、定列是類別表中的ID(或者名稱均可)。(2)查詢汽車用品網上商城的每天的接單數。分析:訂單相關,此處使用聚合函數COUNT()和Group by 子句?!緦嶒?.7】 SUM()查詢該商城每天的銷售額。分析:在訂單表中,有一列是訂單總價,將所有訂單的訂單總價求和,按照下單日期分組,使用SUM()函數和Group by子句?!緦嶒?.8】AVG()(1)查詢所有訂單的平均銷售金額。分析:同上一個相同,還是在訂單表中,依然取用訂單總價列,使用AVG()函數,對指定列的值求平均數?!緦嶒?.9】MAX()(1)查詢所有商品中的數量最大者。分析:商品的數量信息存在于商品表中,此處查詢應該去商品表,在商
8、品數量指定列中求值最大者。使用MAX()函數。(2)查詢所有用戶按字母排序中名字最靠前者。分析:MAX()或者MIN()也可以用在文本列,以獲得按字母順序排列的最高或者最低者。同上一個實驗一樣,使用MAX()函數?!緦嶒?.10】MIN()(1)查詢所有商品中價格最低者。分析:同MAX()用法相同,找到表和列,使用MIN()函數。3.連接查詢【實驗2.11】內連接查詢(1)查詢所有訂單的發(fā)出者名字。分析:此處訂單的信息需要從訂單表中得到,訂單表中主鍵是訂單號,外鍵是用戶ID,同時查詢需要得到訂單發(fā)出者的姓名,也就是用戶名,因此需要將訂單表和用戶表通過用戶ID進行連接。使用內連接的(INNER)
9、 JOIN語句。(2)查詢每個用戶購物車中的商品名稱。分析:購物車中的信息可以從購物車表中得到,購物車表中有用戶ID和商品ID兩項,通過這兩項可以與商品表連接,從而可以獲得商品名稱。與上一個實驗相似,此查詢使用(INNER) JOIN語句?!緦嶒?.12】外連接查詢(1)查詢列出所有用戶ID,以及他們的評論,如果有的話。分析:此查詢首先需列出所有用戶ID,如果參與過評論的話,再列出相關的評論。此處使用外查詢中的LEFT (OUTER) JOIN語句,注意需將全部顯示的列名寫在JOIN語句左邊。(2)查詢列出所有用戶ID,以及他們的評論,如果有的話。分析:依然是上一個實驗,還可以使用RIGHT
10、(OUTER) JOIN語句,注意需將全部顯示的列名寫在JOIN語句右邊?!緦嶒?.13】復合條件連接查詢(1)查詢用戶ID為1的客戶的訂單信息和客戶名。分析:復合條件連接查詢是在連接查詢的過程中,通過添加過濾條件,限制查詢的結果,使查詢的結果更加準確。此查詢需在內查詢的基礎上加上另一個條件,用戶iD為1,使用AND語句添加精確條件。(2)查詢每個用戶的購物車中的商品價格,并且按照價格順序排列。分析:此查詢需要先使用內連接對商品表和購物車表進行連接,得到商品的價格,在使用ORDER BY語句對價格進行順序排列。4.嵌套查詢【實驗2.14】 IN(1)查詢訂購商品ID為1的訂單ID,并根據訂單I
11、D查詢發(fā)出此訂單的用戶ID。分析:此查詢需要使用IN關鍵字進行子查詢,子查詢是通過SELECT語句在訂單明細表中先確定此訂單ID,在通過SELECT在訂單表中查詢到用戶ID。(2)查詢訂購商品ID為1的訂單ID,并根據訂單ID查詢未發(fā)出此訂單的用戶ID。分析:此查詢和前一個實驗相似,只是需使用NOT IN語句。【實驗2.15】比較運算符(1)查詢今年新增會員的訂單,并且列出所有訂單總價小于100的訂單ID。分析:此查詢需要使用嵌套,子查詢需先查詢用戶表得到今年創(chuàng)建的用戶信息,在將用戶ID匹配找打訂單信息,其中使用比較運算符提供訂單總價小于100的條件。(2)查詢所有訂單商品數量總和小于100的
12、商品ID,并將不在此商品所在類別的其他類別的ID列出來。分析:此查詢需要進行嵌套查詢,子查詢過程需要使用到SUM()函數和GROUP BY求出同種商品的所有被訂數量,使用比較運算符得到數量總和小于100的商品ID,再使用比較運算符“不等于”得到非此商品所在類的類別ID?!緦嶒?.16】EXISTS(1)查詢表中是否存在用戶ID為100的用戶,如果存在,列出此用戶的信息。分析:EXISTS關鍵字后面的參數是一個任意的子查詢,系統(tǒng)對于查詢進行運算以判斷它是否返回行,如果至少返回一行,那以EXISTS的結果為TRUE,此時外層查詢語句將進行查詢。此查詢需要對用戶ID進行EXIST操作。(2)查詢表中
13、是否存在類別ID為100的商品類別,如果存在,列出此類別中商品價格小于5的商品ID。分析:與上一個實驗相似,此實驗在外查詢過程添加了比較運算符?!緦嶒?.17】ANY查詢所有商品表中價格比訂單表中商品ID對應的價格大的商品ID。分析:ANY關鍵字在一個比較操作符的后面,表示若與子查詢返回的任何值比較為TRUE,則返回TRUE。此處使用ANY來引出內查詢。【實驗2.18】ALL查詢所有商品表中價格比訂單表中所有商品ID對應的價格大的商品ID。分析:使用ALL時需要同時滿足所有內層查詢的條件。ALL關鍵字在一個比較操作符的后面,表示與子查詢返回的所有值比較為TRUE,則返回TRUE。此處使用ALL
14、來引出內查詢?!緦嶒?.19】集合查詢(1)查詢所有價格小于5的商品,查詢類別ID為1和2的所有商品,使用UNION連接查詢結果。分析:由前所述,UNION將多個SELECT語句的結果組合成一個結果集合,第1條SELECT語句查詢價格小于5的商品,第2條SELECT語句查詢類別ID為1和2的商品,使用UNION將兩條SELECT語句分隔開,執(zhí)行完畢之后把輸出結果組合為單個的結果集,并刪除重復的記錄。(2)查詢所有價格小于5的商品,查詢類別ID為1和2的所有商品,使用UNION ALL連接查詢結果。分析:使用UNION ALL包含重復的行,在前面的例子中,分開查詢時,兩個返回結果中有相同的記錄,
15、使用UNION會自動去除重復行。UNION ALL從查詢結果集中自動要返回所有匹配行,而不進行刪除。實驗要求:1所有操作必須通過MySQL Workbench完成;2每執(zhí)行一種查詢語句后,均要求通過MySQL Workbench查看執(zhí)行結果;3將操作過程以屏幕抓圖的方式拷貝,形成實驗文檔。實驗訓練3 數據增刪改操作請到電腦端查看實驗目的:基于實驗1創(chuàng)建的汽車用品網上商城數據庫Shopping,練習Insert、Delete、TRUNCATE TABLE、Update語句的操作方法,理解單記錄插入與批量插入、DELETE與TRUNCATE TABLE語句、單表修改與多表修改的區(qū)別。實驗內容:【實
16、驗3-1】插入數據(1)使用單記錄插入Insert語句分別完成汽車配件表Autoparts、商品類別表category、用戶表Client 、用戶類別表Clientkind 、購物車表shoppingcart、訂單表Order、訂單明細表order_has_Autoparts、評論Comment的數據插入,數據值自定;并通過select語句檢查插入前后的記錄情況。(2)使用帶Select的Insert語句完成汽車配件表Autoparts中數據的批量追加;并通過select語句檢查插入前后的記錄情況?!緦嶒?-2】刪除數據(1)使用Delete語句分別完成購物車表shoppingcart、訂單表
17、Order、訂單明細表Order_has_Autoparts、評論Comment的數據刪除,刪除條件自定;并通過select語句檢查刪除前后的記錄情況。(2)使用TRUNCATE TABLE語句分別完成購物車表shoppingcart、評論Comment的數據刪除。【實驗3-3】修改數據使用Update分別完成汽車配件表Autoparts、商品類別表category、用戶表Client、用戶類別表Clientkind、購物車表shoppingcart、訂單表Order、訂單明細表Order_has_Autoparts、評論Comment的數據修改,修改后數據值自定,修改條件自定;并通過sele
18、ct語句檢查修改前后的記錄情況。實驗要求:1所有操作必須通過MySQL Workbench完成;2每執(zhí)行一種插入、刪除或修改語句后,均要求通過MySQL Workbench查看執(zhí)行結果及表中數據的變化情況;3將操作過程以屏幕抓圖的方式拷貝,形成實驗文檔。實驗訓練4:數據庫系統(tǒng)維護請到電腦端查看實驗目的:基于實驗1創(chuàng)建的汽車用品網上商城,練習創(chuàng)建用戶、權限管理,數據庫備份與恢復方法,數據導出導入的方法,體會數據庫系統(tǒng)維護的主要工作。實驗內容:1數據庫安全性【實驗6-1】建立賬戶:創(chuàng)建一個用戶名為Teacher密碼為T99999的用戶;創(chuàng)建一個用戶名為Student密碼為S11111的用戶。【實驗
19、6-2】用戶授權:將Shopping數據庫上SELECT、INSERT、DELETE、UPDATE的權限授予Teacher用戶;將Shopping數據庫上SELECT的權限授予Student用戶?!緦嶒?-3】以Teacher用戶身份連接Shopping數據庫,分別執(zhí)行SELECT、INSERT、DELETE、UPDATE、CREATE操作,查看執(zhí)行結果;以Student用戶身份連接Shopping數據庫,執(zhí)行SELECT、INSERT、DELETE、UPDATE操作,查看執(zhí)行結果。2數據庫備份與恢復【實驗6-4】使用mysqldump工具對Shopping數據庫進行備份,查看備份文件?!緦嶒?/p>
20、6-5】對Shopping數據庫啟用二進制日志,并且查看日志?!緦嶒?-6】使用mysqldump工具對Shopping數據庫進行恢復,查看恢復前后Shopping數據庫的數據狀態(tài)。3數據導入導出【實驗6-7】分別使用SELECT INTO、MySQL命令、MySQL Workbench完成Shopping數據庫中會員表和汽車配件表的導出,查看導出結果。【實驗6-8】分別使用LOAD DATA、MySQLIMPORT、MySQL Workbench完成Shopping數據庫中會員表和汽車配件表的導入,查看導入結果。實驗要求:1所有操作均在命令行和MySQL Workbench中完成;2將操作過程以屏幕抓圖的方式拷貝,形成實驗文檔。9 / 9.