2021年電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案_第1頁
2021年電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案_第2頁
2021年電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案_第3頁
2021年電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案_第4頁
2021年電大Oracle數(shù)據(jù)庫編程形考任務(wù)4答案_第5頁
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡(jiǎn)介

2021年國家開放大學(xué)電大Oracle數(shù)據(jù)庫編程形考任務(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ù)庫表中的字段名區(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)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論