下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
2021年國(guó)家開放大學(xué)電大Oracle數(shù)據(jù)庫(kù)編程形考任務(wù)4答案
形考任務(wù)4教學(xué)實(shí)踐3
創(chuàng)建一個(gè)存儲(chǔ)過程,實(shí)現(xiàn)在user.tables查詢參數(shù)給出的表名是否存在,并從存儲(chǔ)過程中返
回結(jié)果。
創(chuàng)建一個(gè)名稱為sch的數(shù)據(jù)表,表結(jié)構(gòu)如表1所示,將表2中的數(shù)據(jù)插入sch表中。
字段名數(shù)據(jù)類型主鍵外鍵非空唯一自增
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
通過select*fromsch來查看插入表格的內(nèi)容,SQL語句如下:
idnameglass
1xiaomingglass1
2xiaojunglass2
第二步:創(chuàng)建一個(gè)存儲(chǔ)函數(shù)用來統(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ù)名稱為count_sch,通過selectcount_sch()查看函數(shù)執(zhí)行的情況,這個(gè)表中只
有兩條記錄,得到的結(jié)果也是兩條記錄,說明函數(shù)成功執(zhí)行。
第三步:創(chuàng)建一個(gè)存儲(chǔ)過程,通過調(diào)用存儲(chǔ)函數(shù)的方法來獲取表sch中的記錄數(shù)和sch表中
id的和。
創(chuàng)建一個(gè)存儲(chǔ)過程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ǔ)過程創(chuàng)建
了一個(gè)curjd的光標(biāo),使用這個(gè)光標(biāo)來獲取每條記錄的id,使用repeat循環(huán)語句來實(shí)現(xiàn)所
有id號(hào)相加。
幾個(gè)小問題:
1、MySQL存儲(chǔ)過程和存儲(chǔ)函數(shù)有什么區(qū)別?
?本質(zhì)上都是存儲(chǔ)程序。函數(shù)只能通過return語句返回單個(gè)值或表對(duì)象;存儲(chǔ)過程不
允許執(zhí)行return,但可以通過out參數(shù)返回多個(gè)值。
?函數(shù)限制比較多,不能用臨時(shí)表,只能用表變量,還有一些函數(shù)都不可用。存儲(chǔ)過
程的限制相對(duì)就比較少。
?函數(shù)可以嵌入sql語句中使用,可以在select語句中作為查詢語句中的一個(gè)部分調(diào)用,
而存儲(chǔ)過程一般是作為一個(gè)獨(dú)立的部分來執(zhí)行。
2.存儲(chǔ)過程中的代碼可以改變嗎?
?MySQL還不提供對(duì)已存在的存儲(chǔ)過程代碼的修改。如果必須修改存儲(chǔ)過程,就必須
使用drop語句刪除之后再重新編寫,或者創(chuàng)建一個(gè)新的存儲(chǔ)過程。
3.存儲(chǔ)過程中可以調(diào)用其他存儲(chǔ)過程嗎?
存儲(chǔ)過程包含用戶定義的sql語句集合,可以使用call語句調(diào)用存儲(chǔ)過程,當(dāng)然在存儲(chǔ)過程
中也可以使用call語句調(diào)用其他存儲(chǔ)程序,但是不能使用drop語句刪除其他存儲(chǔ)過程。
4.存儲(chǔ)過程的參數(shù)不能與數(shù)據(jù)表中的字段名相同。
在定義存儲(chǔ)過程參數(shù)列表時(shí),應(yīng)注意把參數(shù)名與數(shù)據(jù)庫(kù)表中的字段名區(qū)別開,否則將出現(xiàn)無
法預(yù)期的結(jié)果。
5.存儲(chǔ)過程的參數(shù)可以使用中文嗎?
一般情況下,可能會(huì)出現(xiàn)存儲(chǔ)過程中傳入中文參數(shù)的情況,例如,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年安全教育培訓(xùn)管理考核制度范文(三篇)
- 2024年幼兒園保育員工作總結(jié)樣本(二篇)
- 2024年處方藥銷售管理制度樣本(二篇)
- 2024年客服主管個(gè)人工作計(jì)劃(七篇)
- 2024年山林承包合同參考樣本(四篇)
- 2024年小學(xué)班主任工作職責(zé)(二篇)
- 2024年室內(nèi)設(shè)計(jì)合同范文(四篇)
- 2024年安全辦公會(huì)議制度范文(三篇)
- 2024年小學(xué)財(cái)務(wù)預(yù)算管理制度(六篇)
- 2024年單位消防安全責(zé)任制范文(二篇)
- 2024年人教版八年級(jí)數(shù)學(xué)(上冊(cè))期中試卷及答案(各版本)
- 浙江省2024年性選拔干部工作歷年(高頻重點(diǎn)復(fù)習(xí)提升訓(xùn)練)共500題附帶答案詳解
- 江西省綠色建筑評(píng)價(jià)標(biāo)準(zhǔn)
- -投標(biāo)技術(shù)標(biāo)書范文模板-人員配備與團(tuán)隊(duì)構(gòu)建
- 政務(wù)服務(wù)中心物業(yè)服務(wù)投標(biāo)方案【新版】(技術(shù)方案)
- 餐飲服務(wù)食品安全操作規(guī)范2024
- (新版)高級(jí)服裝制版師考試題庫(kù)(濃縮300題)
- 圖書館智慧服務(wù)系統(tǒng)合同
- 人教版(2024新教材)七年級(jí)上冊(cè)數(shù)學(xué)第一章《有理數(shù)》單元測(cè)試卷(含答案)
- 強(qiáng)直性脊柱炎的護(hù)理查房課件
- 頭療培訓(xùn)課件
評(píng)論
0/150
提交評(píng)論