下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
2021年國(guó)家開(kāi)放大學(xué)電大Oracle數(shù)據(jù)庫(kù)編程形考任務(wù)4答案
形考任務(wù)4教學(xué)實(shí)踐3
創(chuàng)建一個(gè)存儲(chǔ)過(guò)程,實(shí)現(xiàn)在user.tables查詢(xún)參數(shù)給出的表名是否存在,并從存儲(chǔ)過(guò)程中返
回結(jié)果。
創(chuàng)建一個(gè)名稱(chēng)為sch的數(shù)據(jù)表,表結(jié)構(gòu)如表1所示,將表2中的數(shù)據(jù)插入sch表中。
字段名數(shù)據(jù)類(lèi)型主鍵外鍵非空唯一自增
idint(10)是否是是否
namevarchar(50)否否是否否
glassvarchar(50)否否是否否
表2:
idnameglass
1xiaomingglassl
2xiaojunglass2
第一步:創(chuàng)建一個(gè)sch表,并向sch表中插入表2中的數(shù)據(jù),代碼如下:
mysql>createtablesch
->(
->idint(lO),
->namevarchar(50),
->glassvarchar(SO)
->);
QueryOK,0rowsaffected(0.11sec)
mysql>insertintoschvaluefl/xiaoming'/glass1'),
->(Z/xiaojun'Jglass2');
QueryOK,2rowsaffected(0.05sec)
Records:2Duplicates:0Warnings:0
mysql>descsch;
+------+-------------+------+-----+---------+-------+
|Field|Type|Null|Key|Default|Extra|
+------+-------------+------+-----+---------+-------+
|id|int(10)|YES||NULL|
|name|varchar(50)|YES||NULL|
|glass|varchar(50)|YES||NULL|
3rowsinset(0.00sec)
?1
?2
?3
?4
5
6
?7
?8
?9
?10
?11
?12
?13
?14
?15
?16
?17
?18
?19
?20
?21
?22
通過(guò)select*fromsch來(lái)查看插入表格的內(nèi)容,SQL語(yǔ)句如下:
idnameglass
1xiaomingglass1
2xiaojunglass2
第二步:創(chuàng)建一個(gè)存儲(chǔ)函數(shù)用來(lái)統(tǒng)計(jì)表sch中的記錄數(shù)。
mysql>createfunctioncount_sch()
->returnsint
->return(selectcount(*)fromsch);
QueryOK,0rowsaffected(0.05sec)
mysql>selectcount_sch();
|count_sch()|
2I
+
1rowinset(0.00sec)
?1
?2
?3
?4
?5
?6
?7
?8
?9
?10
11
?12
創(chuàng)建的存儲(chǔ)函數(shù)名稱(chēng)為count_sch,通過(guò)selectcount_sch()查看函數(shù)執(zhí)行的情況,這個(gè)表中只
有兩條記錄,得到的結(jié)果也是兩條記錄,說(shuō)明函數(shù)成功執(zhí)行。
第三步:創(chuàng)建一個(gè)存儲(chǔ)過(guò)程,通過(guò)調(diào)用存儲(chǔ)函數(shù)的方法來(lái)獲取表sch中的記錄數(shù)和sch表中
id的和。
創(chuàng)建一個(gè)存儲(chǔ)過(guò)程add_id,同時(shí)使用前面創(chuàng)建的存儲(chǔ)函數(shù)返回表sch中的記錄數(shù),計(jì)算出表
中所有的id之和。代碼如下:
mysql>delimiter//
mysql>createprocedureaddjd(outcountint)
->begin
->declareitmpint;
->declarecurjdcursorforselectidfromsch;
->declareexithandlerfornotfoundclosecurjd;
->selectcount_sch()intocount;
->set@sum=0;
->opencurjd;
->repeat
->fetchcurjdintoitmp;
->ifitmp<10
->thenset@sum=@sum+itmp;
->endif;
->until0endrepeat;
->closecurjd;
->end//
QueryOK,0rowsaffected(0.06sec)
mysql>select@a,@sum//
|@a|@sum|
|NULL|NULL|
1rowinset(0.00sec)
mysql>delimiter;
?1
?2
?3
?4
?5
?6
?7
?8
?9
?10
?11
?12
?13
?14
?15
?16
?17
?18
?19
?20
?21
?22
?23
?24
?25
?26
?27
?28
表sch中只有兩條記錄,所有id的和為3,和預(yù)想的執(zhí)行結(jié)果完全相同。這個(gè)存儲(chǔ)過(guò)程創(chuàng)建
了一個(gè)curjd的光標(biāo),使用這個(gè)光標(biāo)來(lái)獲取每條記錄的id,使用repeat循環(huán)語(yǔ)句來(lái)實(shí)現(xiàn)所
有id號(hào)相加。
幾個(gè)小問(wèn)題:
1、MySQL存儲(chǔ)過(guò)程和存儲(chǔ)函數(shù)有什么區(qū)別?
?本質(zhì)上都是存儲(chǔ)程序。函數(shù)只能通過(guò)return語(yǔ)句返回單個(gè)值或表對(duì)象;存儲(chǔ)過(guò)程不
允許執(zhí)行return,但可以通過(guò)out參數(shù)返回多個(gè)值。
?函數(shù)限制比較多,不能用臨時(shí)表,只能用表變量,還有一些函數(shù)都不可用。存儲(chǔ)過(guò)
程的限制相對(duì)就比較少。
?函數(shù)可以嵌入sql語(yǔ)句中使用,可以在select語(yǔ)句中作為查詢(xún)語(yǔ)句中的一個(gè)部分調(diào)用,
而存儲(chǔ)過(guò)程一般是作為一個(gè)獨(dú)立的部分來(lái)執(zhí)行。
2.存儲(chǔ)過(guò)程中的代碼可以改變嗎?
?MySQL還不提供對(duì)已存在的存儲(chǔ)過(guò)程代碼的修改。如果必須修改存儲(chǔ)過(guò)程,就必須
使用drop語(yǔ)句刪除之后再重新編寫(xiě),或者創(chuàng)建一個(gè)新的存儲(chǔ)過(guò)程。
3.存儲(chǔ)過(guò)程中可以調(diào)用其他存儲(chǔ)過(guò)程嗎?
存儲(chǔ)過(guò)程包含用戶(hù)定義的sql語(yǔ)句集合,可以使用call語(yǔ)句調(diào)用存儲(chǔ)過(guò)程,當(dāng)然在存儲(chǔ)過(guò)程
中也可以使用call語(yǔ)句調(diào)用其他存儲(chǔ)程序,但是不能使用drop語(yǔ)句刪除其他存儲(chǔ)過(guò)程。
4.存儲(chǔ)過(guò)程的參數(shù)不能與數(shù)據(jù)表中的字段名相同。
在定義存儲(chǔ)過(guò)程參數(shù)列表時(shí),應(yīng)注意把參數(shù)名與數(shù)據(jù)庫(kù)表中的字段名區(qū)別開(kāi),否則將出現(xiàn)無(wú)
法預(yù)期的結(jié)果。
5.存儲(chǔ)過(guò)程的參數(shù)可以使用中文嗎?
一般情況下,可能會(huì)出現(xiàn)存儲(chǔ)過(guò)程中傳入中文參數(shù)的情況,例如,
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年高新技術(shù)產(chǎn)品銷(xiāo)售合同管理規(guī)定2篇
- 二零二五年度游艇購(gòu)置及保養(yǎng)維修協(xié)議3篇
- 2025版智能節(jié)能鋁合金門(mén)窗研發(fā)與推廣合作協(xié)議4篇
- 2025年項(xiàng)目抵押貸款合同范本解讀與實(shí)操6篇
- 2025版醫(yī)療器械融資委托擔(dān)保合同樣本3篇
- 二零二五年度貨車(chē)貨運(yùn)保險(xiǎn)與物流行業(yè)信用評(píng)估合同
- 2025年度智能機(jī)器人銷(xiāo)售與技術(shù)支持協(xié)議3篇
- 2025版新型綠色建筑材料供應(yīng)及施工合同4篇
- 2025版中英外教專(zhuān)業(yè)能力培訓(xùn)與雇傭合同3篇
- 個(gè)體資金借入合同:固定期限還款合同版
- 圖像識(shí)別領(lǐng)域自適應(yīng)技術(shù)-洞察分析
- 個(gè)體戶(hù)店鋪?zhàn)赓U合同
- 新概念英語(yǔ)第二冊(cè)考評(píng)試卷含答案(第49-56課)
- 【奧運(yùn)會(huì)獎(jiǎng)牌榜預(yù)測(cè)建模實(shí)證探析12000字(論文)】
- 保安部工作計(jì)劃
- 2023痛風(fēng)診療規(guī)范(完整版)
- (完整word版)企業(yè)對(duì)賬函模板
- 土力學(xué)與地基基礎(chǔ)(課件)
- 主要負(fù)責(zé)人重大隱患帶隊(duì)檢查表
- 魯濱遜漂流記人物形象分析
- 危險(xiǎn)廢物貯存?zhèn)}庫(kù)建設(shè)標(biāo)準(zhǔn)
評(píng)論
0/150
提交評(píng)論