若需要在特定數(shù)據(jù)庫(kù)中創(chuàng)建存儲(chǔ)過程,則要在名稱前面加上數(shù)據(jù)庫(kù)的名稱,即 db_name.sp_name。需要注意的是,名稱應(yīng)當(dāng)盡量避免選取與 MySQL 內(nèi)置函數(shù)相同的名稱,否則會(huì)發(fā)生錯(cuò)誤。2) 過程參數(shù)存儲(chǔ)過程的參數(shù)列表。
10多年的丁青網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營(yíng)銷推廣的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整丁青建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)公司從事“丁青網(wǎng)站設(shè)計(jì)”,“丁青網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
存儲(chǔ)過程是數(shù)據(jù)庫(kù)中的一個(gè)重要對(duì)象,任何一個(gè)設(shè)計(jì)良好的數(shù)據(jù)庫(kù)應(yīng)用程序都應(yīng)該用到存儲(chǔ)過程。
MySQL中的存儲(chǔ)過程指的是存儲(chǔ)在數(shù)據(jù)庫(kù)中的SQL語(yǔ)句集合,當(dāng)創(chuàng)建好存儲(chǔ)過程后在運(yùn)行時(shí)提供所需參數(shù),存儲(chǔ)過程就可以以代碼指定的方式使用參數(shù)執(zhí)行并返回值在MySQL中提供了創(chuàng)建存儲(chǔ)過程的能力。
但是MySQL在0以前并不支持存儲(chǔ)過程,這使得MySQL在應(yīng)用上大打折扣。好在MySQL 0終于開始已經(jīng)支持存儲(chǔ)過程,這樣即可以大大提高數(shù)據(jù)庫(kù)的處理速度,同時(shí)也可以提高數(shù)據(jù)庫(kù)編程的靈活性。
語(yǔ)法格式:可以使用 CREATE PROCEDURE 語(yǔ)句創(chuàng)建存儲(chǔ)過程。
如何創(chuàng)建MySQL存儲(chǔ)過程可以返回一個(gè)表類型的數(shù)據(jù) 首先需要知道“另一個(gè)存儲(chǔ)過程”的結(jié)果集的所有列的類型。
MySQL 創(chuàng)建存儲(chǔ)過程 “pr_add” 是個(gè)簡(jiǎn)單的 MySQL 存儲(chǔ)過程,這個(gè)存儲(chǔ)過程有兩個(gè) int 類型的輸入?yún)?shù) “a”、“b”,返回這兩個(gè)參數(shù)的和。
1、MySQL默認(rèn)的存儲(chǔ)引擎是MyISAM(7版本中默認(rèn)為InnoDB)。配置文件中設(shè)置默認(rèn)存儲(chǔ)引擎的參數(shù):default-table-type。
2、MySQL有多種存儲(chǔ)引擎:MyISAM、InnoDB、MERGE、MEMORY(HEAP)、BDB(BerkeleyDB)、EXAMPLE、FEDERATED、ARCHIVE、CSV、BLACKHOLE。MySQL支持?jǐn)?shù)個(gè)存儲(chǔ)引擎作為對(duì)不同表的類型的處理器。
3、表 1 MySQL 的存儲(chǔ)引擎存儲(chǔ)引擎描述ARCHIVE用于數(shù)據(jù)存檔的引擎,數(shù)據(jù)被插入后就不能在修改了,且不支持索引。CSV在存儲(chǔ)數(shù)據(jù)時(shí),會(huì)以逗號(hào)作為數(shù)據(jù)項(xiàng)之間的分隔符。BLACKHOLE會(huì)丟棄寫操作,該操作會(huì)返回空內(nèi)容。
4、事務(wù)。InnoDB存儲(chǔ)引擎是支持事務(wù)的標(biāo)準(zhǔn)MySQL存儲(chǔ)引擎。自動(dòng)災(zāi)難恢復(fù)。與其它存儲(chǔ)引擎不同,InnoDB表能夠自動(dòng)從災(zāi)難中恢復(fù)。外鍵約束。MySQL支持外鍵的存儲(chǔ)引擎只有InnoDB。
5、MyIASM引擎MyIASM是MySQL默認(rèn)的引擎,但是它沒有提供對(duì)數(shù)據(jù)庫(kù)事務(wù)的支持,也不支持行級(jí)鎖和外鍵,因此當(dāng)INSERT(插入)或UPDATE(更 新)數(shù)據(jù)時(shí)即寫操作需要鎖定整個(gè)表,效率便會(huì)低一些。
6、MySQL常見的三種存儲(chǔ)引擎為InnoDB、MyISAM和MEMORY。其區(qū)別體現(xiàn)在事務(wù)安全、存儲(chǔ)限制、空間使用、內(nèi)存使用、插入數(shù)據(jù)的速度和對(duì)外鍵的支持。具體如下:事務(wù)安全:InnoDB支持事務(wù)安全,MyISAM和MEMORY兩個(gè)不支持。
若需要在特定數(shù)據(jù)庫(kù)中創(chuàng)建存儲(chǔ)過程,則要在名稱前面加上數(shù)據(jù)庫(kù)的名稱,即 db_name.sp_name。需要注意的是,名稱應(yīng)當(dāng)盡量避免選取與 MySQL 內(nèi)置函數(shù)相同的名稱,否則會(huì)發(fā)生錯(cuò)誤。2) 過程參數(shù)存儲(chǔ)過程的參數(shù)列表。
推薦課程:MySql教程。存儲(chǔ)過程的優(yōu)點(diǎn):(1).增強(qiáng)SQL語(yǔ)言的功能和靈活性:存儲(chǔ)過程可以用控制語(yǔ)句編寫,有很強(qiáng)的靈活性,可以完成復(fù)雜的判斷和較復(fù)雜的運(yùn)算。
第一步,創(chuàng)建一個(gè)存儲(chǔ)過程,該代碼如圖所示。存儲(chǔ)過程的主要目的是為表“JingYan”插入新數(shù)據(jù),如下圖所示,然后進(jìn)入下一步。其次,完成上述步驟后,執(zhí)行以下幾行代碼,并查看執(zhí)行是否成功。
本文實(shí)例講述了MySQL存儲(chǔ)過程中實(shí)現(xiàn)執(zhí)行動(dòng)態(tài)SQL語(yǔ)句的方法。分享給大家供大家參考。
存儲(chǔ)過程中執(zhí)行動(dòng)態(tài)Sql語(yǔ)句 MSSQL為我們提供了兩種動(dòng)態(tài)執(zhí)行SQL語(yǔ)句的命令,分別是EXEC和sp_executesql;通常,sp_executesql則更具有優(yōu)勢(shì),它提供了輸入輸出接口,而EXEC沒有。
第三步: 編譯存儲(chǔ)過程,在工具欄上按下執(zhí)行按鈕,如果沒有錯(cuò)誤,就編寫成功了。第四步:調(diào)用:在sqlserver的語(yǔ)句查詢框中,輸入exec 存儲(chǔ)過程名 參數(shù),執(zhí)行就可以了。
1、pr_add 是個(gè)簡(jiǎn)單的 MySQL 存儲(chǔ)過程,這個(gè)MySQL 存儲(chǔ)過程有兩個(gè) int 類型的輸入?yún)?shù) a、b,返回這兩個(gè)參數(shù)的和。
2、基本語(yǔ)法 (1)創(chuàng)建:(2)調(diào)用:(3)查看:(4)刪除 注意: 在命令行中,執(zhí)行創(chuàng)建存儲(chǔ)過程的SQL時(shí),需要通過關(guān)鍵字 delimiter 指定SQL語(yǔ)句的 結(jié)束符。
3、存儲(chǔ)過程可以沒有參數(shù)(此時(shí)存儲(chǔ)過程的名稱后仍需加上一對(duì)括號(hào)),也可以有 1 個(gè)或多個(gè)參數(shù)。MySQL 存儲(chǔ)過程支持三種類型的參數(shù),即輸入?yún)?shù)、輸出參數(shù)和輸入/輸出參數(shù),分別用 IN、OUT 和 INOUT 三個(gè)關(guān)鍵字標(biāo)識(shí)。