中南大學(xué)數(shù)據(jù)庫實驗報告_第1頁
中南大學(xué)數(shù)據(jù)庫實驗報告_第2頁
中南大學(xué)數(shù)據(jù)庫實驗報告_第3頁
中南大學(xué)數(shù)據(jù)庫實驗報告_第4頁
中南大學(xué)數(shù)據(jù)庫實驗報告_第5頁
已閱讀5頁,還剩13頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、中 南 大 學(xué)數(shù)據(jù)庫實驗 實驗題目 班 級 姓 名學(xué) 號 一、實驗內(nèi)容實驗一:創(chuàng)建表、更新表和實施數(shù)據(jù)完整性1 運行給定的SQL Script,建立數(shù)據(jù)庫GlobalToyz。2 創(chuàng)建所有表的關(guān)系圖。3 列出所有表中出現(xiàn)的約束(包括Primary key, Foreign key, check constraint, default, unique)4 對Recipient表和Country表中的cCountryId屬性定義一個用戶自定義數(shù)據(jù)類型,并將該屬性的類型定義為這個自定義數(shù)據(jù)類型。5 把價格在$20以上的所有玩具的材料拷貝到稱為PremiumToys的新表中。6 對表Toys實施下面數(shù)

2、據(jù)完整性規(guī)則:(1)玩具的現(xiàn)有數(shù)量應(yīng)在0到200之間;(2)玩具適宜的最低年齡缺省為1。7 不修改已創(chuàng)建的Toys表,利用規(guī)則實現(xiàn)以下數(shù)據(jù)完整性:(1)玩具的價格應(yīng)大于0;(2)玩具的重量應(yīng)缺省為1。8 給id為000001玩具的價格增加$1。實驗二:查詢數(shù)據(jù)庫1. 顯示屬于California和Illinoi州的顧客的名、姓和emailID。2. 顯示定單號碼、商店ID,定單的總價值,并以定單的總價值的升序排列。3. 顯示在orderDetail表中vMessage為空值的行。4. 顯示玩具名字中有“Racer”字樣的所有玩具的材料。5. 根據(jù)2000年的玩具銷售總數(shù),顯示“Pick of

3、the Month”玩具的前五名玩具的ID。6. 根據(jù)OrderDetail表,顯示玩具總價值大于¥50的定單的號碼和玩具總價值。7. 顯示一份包含所有裝運信息的報表,包括:Order Number, Shipment Date, Actual Delivery Date, Days in Transit. (提示:Days in Transit = Actual Delivery Date Shipment Date)8. 顯示所有玩具的名稱、商標(biāo)和種類(Toy Name, Brand, Category)。9. 顯示玩具的名稱和所有玩具的購物車ID。如果玩具不在購物車中,則顯示NULL值。

4、10. 以下列格式顯示所有購物者的名字和他們的簡稱:(Initials, vFirstName, vLastName),例如Angela Smith的Initials為A.S。11. 顯示所有玩具的平均價格,并舍入到整數(shù)。 12. 顯示所有購買者和收貨人的名、姓、地址和所在城市。13. 顯示沒有包裝的所有玩具的名稱。(要求用子查詢實現(xiàn))14. 顯示已發(fā)貨定單的定單號碼以及下定單的時間。(要求用子查詢實現(xiàn))實驗三:視圖與觸發(fā)器1. 定義一個視圖,包括購買者的姓名、所在州和他們所訂購?fù)婢叩拿Q、價格和數(shù)量。2. 基于(1)中定義的視圖,查詢顯示所有California州的購買者的姓名和他們所訂購?fù)?/p>

5、具的名稱及數(shù)量。3. 視圖定義如下: CREATE VIEW vwOrderWrapper AS SELECT cOrderNo, cToyId, siQty, vDescription, mWrapperRate FROM OrderDetail JOIN Wrapper ON OrderDetail.cWrapperId = Wrapper.cWrapperId以下更新命令,在更新siQty和mWrapperRate屬性使用了以下更新命令時出現(xiàn)錯誤: UPDATE vwOrderWrapper SET siQty = 2, mWrapperRate = mWrapperRate + 1 F

6、ROM vwOrderWrapper WHERE cOrderNo = 000001修改更新命令,以更新基表中的值。4. 在OrderDetail上定義一個觸發(fā)器,如果購物者改變了定單的數(shù)量,玩具的成本也自動地改變。(提示:Toy cost = Quantity * Toy Rate)實驗四:存儲過程1. 編寫一段程序,將每種玩具的價格提高¥0.5,直到玩具的平均價格接近$24.5為止。此外,任何玩具的最大價格不應(yīng)超過$53。2. 創(chuàng)建一個稱為prcCharges的存儲過程,它返回某個定單號的裝運費用和包裝費用。3. 創(chuàng)建一個稱為prcHandlingCharges的過程,它接收定單號并顯示經(jīng)

7、營費用。PrchandlingCharges過程應(yīng)使用prcCharges過程來得到裝運費和禮品包裝費。提示:經(jīng)營費用=裝運費+禮品包裝費 實驗五:事務(wù)與游標(biāo)1. 名為prcGenOrder的存儲過程產(chǎn)生存在于數(shù)據(jù)庫中的定單號: CREATE PROCEDURE prcGenOrder OrderNo char(6) OUTPUT as SELECT OrderNo=Max(cOrderNo) FROM Orders SELECT OrderNo= CASE WHEN OrderNo=0 and OrderNo=9 and OrderNo=99 and OrderNo=999 and Orde

8、rNo=9999 and OrderNo=99999 Then Convert(char,OrderNo+1) END RETURN當(dāng)購物者確認(rèn)定單時,應(yīng)該出現(xiàn)下面的步驟:(1)用上面的過程產(chǎn)生定單號。(2)定單號,當(dāng)前日期,購物車ID,和購物者ID應(yīng)該加到Orders表中。(3)定單號,玩具ID,和數(shù)量應(yīng)加到OrderDetail表中。(4)在OrderDetail表中更新玩具成本。(提示:Toy cost = Quantity * Toy Rate).將上述步驟定義為一個事務(wù)。編寫一個過程以購物車ID和購物者ID為參數(shù),實現(xiàn)這個事務(wù)。2. 編寫一個程序顯示每天的定單狀態(tài)。如果當(dāng)天的定單值總

9、合大于170,則顯示“High sales”,否則顯示”Low sales”.報告中要求列出日期、定單狀態(tài)和定單總價值。二、實驗?zāi)康?熟悉SQL語言,加深對數(shù)據(jù)庫知識的認(rèn)識。學(xué)會用SQL語言解決實際數(shù)據(jù)庫問題。三、實驗源代碼實驗一、-3 /*sp_helpconstraint objname=Categorygo sp_helpconstraint objname=Countrygo sp_helpconstraint objname=OrderDetailgosp_helpconstraint objname=PickOfMonthgo sp_helpconstraint objname=C

10、ategorygo sp_helpconstraint objname=Recipientgo sp_helpconstraint objname=Shipmentgo sp_helpconstraint objname=ShippingModego sp_helpconstraint objname=ShippingRatego sp_helpconstraint objname=Shoppergo sp_helpconstraint objname=ShoppingCartgo sp_helpconstraint objname=ToyBrandgosp_helpconstraint ob

11、jname=Toysgo sp_helpconstraint objname=Wrapper; */ -4 create type xianke from char(3)alter table Recipient alter column cCountryId kkalter table Countryalter column cCountryId kk5.USE GlobalToyzGOCREATE TABLE PremiumToys ( cToyIdchar(6) primary key,vToyNamevarchar(20) not null,vToyDescriptionvarchar

12、(250),cCategoryIdchar(3) ,mToyRatemoney not null,cBrandIdchar(3),imPhoto image,siToyQohsmallint not null,siLowerAgesmallint not null,siUpperAgesmallint not null,siToyWeightsmallint,vToyImgPathvarchar(50) null)INSERT INTO PremiumToysSELECT * FROM Toys WHERE mToyRate206.7.ALTER Table Toys ADD siToyQoh

13、 smallint CHECK(siToyQoh=0 AND siToyQoh0)ALTER TABLE Toys ADD siToyWeight CHECK(siToyWeigh=1)(cToyId char(6) primary key,vToyNamevarchar(20) not null,vToyDescriptionvarchar(250),cCategoryIdchar(3),mToyRatemoney not null(mToyRate0),cBrandIdchar(3),imPhoto image,siLowerAgesmallint not null,siUpperAges

14、mallint not null,siToyWeightsmallint,vToyImgPathvarchar(50) null)8.update ToysSet mToyRate=mToyRate+1Where cToyId=000001實驗二 1. SELECT vFirstName ,vLastName ,vEmailId FROM GlobalToyz.dbo.Shopper WHERE cState = California OR cState = IllinoisGO2. SELECT cOrderNo ,cShopperId ,mTotalCost FROM GlobalToyz

15、.dbo.Orders ORDER BY mTotalCost ASCGO3. SELECT * FROM GlobalToyz.dbo.OrderDetail WHERE vMessage IS NULLGO4. SELECT top 5 cToyId ,siMonth ,iYear ,iTotalSold FROM GlobalToyz.dbo.PickOfMonth WHERE iYear = 2000 ORDER BY iTotalSold DESCGO5. SELECT top 5 cToyId ,siMonth ,iYear ,iTotalSold FROM GlobalToyz.

16、dbo.PickOfMonth WHERE iYear = 2000 ORDER BY iTotalSold DESCGO6. SELECT cOrderNo ,mToyCost FROM GlobalToyz.dbo.OrderDetail WHERE mToyCost 50GO7. SELECT vToyName ,ToyBrand.cBrandId ,ToyBrand.cBrandName ,Category.cCategoryId ,Category.cCategory ,Category.vDescription FROM GlobalToyz.dbo.Toys, GlobalToy

17、z.dbo.ToyBrand, tegory WHERE toys.cBrandId = ToyBrand.cBrandId AND toys.cCategoryId = Category.cCategoryIdGO8. SELECT vToyName ,ToyBrand.cBrandId ,ToyBrand.cBrandName ,Category.cCategoryId ,Category.cCategory ,Category.vDescription FROM GlobalToyz.dbo.Toys, GlobalToyz.dbo.ToyBrand, tegory WHERE toys

18、.cBrandId = ToyBrand.cBrandId AND toys.cCategoryId = Category.cCategoryIdGO9. SELECT vToyName ,ShoppingCart.cCartId FROM GlobalToyz.dbo.Toys, GlobalToyz.dbo.ShoppingCart WHERE Toys.cToyId = ShoppingCart.cToyIdGO10. SELECT FLOOR(AVG(mToyRate) FROM GlobalToyz.dbo.ToysGO11. SELECT FLOOR(AVG(mToyRate) F

19、ROM GlobalToyz.dbo.ToysGO12. SELECT Shopper.vFirstName ,Shopper.vLastName ,Shopper.vAddress ,Shopper.cCity ,Recipient.vFirstName ,Recipient.vLastName ,Recipient.vAddress ,Recipient.cCity FROM GlobalToyz.dbo.Shopper, GlobalToyz.dbo.RecipientGO13. SELECT vToyName FROM GlobalToyz.dbo.Toys WHERE cToyId

20、IN ( SELECT cToyId FROM GlobalToyz.dbo.OrderDetail WHERE cWrapperId IS NULL )GO14. SELECT cOrderNo ,dOrderDate FROM GlobalToyz.dbo.Orders WHERE cOrderNo IN ( SELECT cOrderNo FROM GlobalToyz.dbo.Shipment WHERE cDeliveryStatus = d )GO實驗三1. CREATE VIEW IS_CHAXUNASSELECT Shopper.vFirstName,Shopper.vLast

21、Name,Shopper.cCity,Toys.vToyName,Toys.mToyRate,OrderDetail.siQtyFROM Shopper,Orders,OrderDetail,ToysWHERE Orders.cOrderNo=OrderDetail.cOrderNo AND Shopper.cShopperId=Orders.cShopperId AND OrderDetail.cToyId=Toys.cToyId;2. SELECT vFirstName,vLastName,vToyName,siQtyFROM IS_CHAXUNWHERE cCity=California

22、;3. UPDATE vwOrderWrapperSET siQty = 2, mWrapperRate = mWrapperRate + 1 FROM vwOrderWrapperWHERE cOrderNo = 0000014. Create Trigger truOD ON OrderDetailFOR UPDATEASIF UPDATE(siQty) BEGIN DECLARE siQty intSELECT siQty=deleted.siQtyFROM deletedUPDATE OrderDetail SET mToyCost=mToyCost/siQty*siQty WHERE

23、 cOrderNo IN (SELECT cOrderNoFROM deleted) END實驗四1. SELECT cOrderNo ,dOrderDate FROM GlobalToyz.dbo.Orders WHERE cOrderNo IN ( SELECT cOrderNo FROM GlobalToyz.dbo.Shipment WHERE cDeliveryStatus = d )GO2. CREATE PROCEDURE prcCharges cOrderNo int,mShippingCharges money OUTPUT, mGiftWrapCharges money O

24、UTPUTASBEGINSELECT cOrderNo=cOrderNo, mShippingCharges =mShippingCharges, mGiftWrapCharges =mGiftWrapChargesFROM OrdersWHERE cOrderNo=cOrderNoEND3. CREATE PROCEDURE prcHandlingCharges cOrderNo intASBEGINDECLARE mScharges money DECLARE mGWcharges moneyEXEC prcCharges cOrderNo,mScharges output, mGWcharges outputRETURN mScharges+mGWchargesEND實驗五1. CREATE PROCEDURE tianjia cCartId char(6),cShopperId char(6),cToyId char(6),siQty smallintASBEGINBEGIN TRANSACTIONDECLARE date datetime;DECLARE mToyRate moneyDECLARE cOrderNo char(6)SELECT da

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論