




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
銷售管理數(shù)據(jù)庫中存儲(chǔ)過程的運(yùn)用第09章銷售管理數(shù)據(jù)庫中存儲(chǔ)過程的應(yīng)用技能目標(biāo)理解存儲(chǔ)過程概念以及存儲(chǔ)過程的作用;學(xué)會(huì)創(chuàng)建、刪除、修改存儲(chǔ)過程;學(xué)會(huì)根據(jù)實(shí)際需要設(shè)計(jì)銷售管理數(shù)據(jù)庫中的存儲(chǔ)過程。知識(shí)目標(biāo)理解存儲(chǔ)過程的作用;了解系統(tǒng)存儲(chǔ)過程和擴(kuò)展存儲(chǔ)過程;掌握存儲(chǔ)過程的基本類型;掌握創(chuàng)建、刪除、修改和加密存儲(chǔ)過程;掌握?qǐng)?zhí)行各類存儲(chǔ)過程存儲(chǔ)過程的概念存儲(chǔ)過程(StoredProcedure)是一組完成特定功能的Transact-SQL語句集,經(jīng)編譯后存儲(chǔ)在數(shù)據(jù)庫中,用戶調(diào)用過程名和給出參數(shù)來調(diào)用它們.特點(diǎn):完成特定功能多條語句組成的程序存放在數(shù)據(jù)庫中(服務(wù)器)由客戶機(jī)調(diào)用可以帶參數(shù),也可以不帶參數(shù)可以有返回值,也可以沒有為什么要建立存儲(chǔ)過程?數(shù)據(jù)庫服務(wù)器客戶機(jī)實(shí)現(xiàn)相同功能的SQL語句集客戶機(jī)實(shí)現(xiàn)相同功能的SQL語句集缺點(diǎn):1.相同的SQL語句要重復(fù)書寫
2.傳輸網(wǎng)絡(luò)面臨較大壓力
3.執(zhí)行效率低
4.存在安全隱患為什么要建立存儲(chǔ)過程?數(shù)據(jù)庫服務(wù)器存儲(chǔ)過程客戶機(jī)調(diào)用存儲(chǔ)過程實(shí)現(xiàn)特定功能客戶機(jī)優(yōu)點(diǎn):1.直接調(diào)用特定存儲(chǔ)過程實(shí)現(xiàn)某種功能,不需要用戶自己書寫SQL語句
2.存儲(chǔ)過程存放在服務(wù)器上,不需網(wǎng)絡(luò)傳輸
3.存儲(chǔ)過程經(jīng)過編譯和優(yōu)化,執(zhí)行效率高
4.安全性高調(diào)用存儲(chǔ)過程實(shí)現(xiàn)特定功能存儲(chǔ)過程的優(yōu)點(diǎn)允許模塊化程序設(shè)計(jì)存儲(chǔ)過程由有數(shù)據(jù)庫專長的技術(shù)人員編寫??梢詿o限次調(diào)用存儲(chǔ)過程獨(dú)立與程序源代碼,維護(hù)方便執(zhí)行速度快存儲(chǔ)過程經(jīng)過編譯存儲(chǔ)過程經(jīng)過優(yōu)化批處理的SQL語句每次均需要編譯和優(yōu)化有效降低網(wǎng)絡(luò)流量只需通過網(wǎng)絡(luò)發(fā)送一條調(diào)用存儲(chǔ)過程的語句,不需要傳遞大量的SQL語句代碼提高數(shù)據(jù)庫的安全性存儲(chǔ)過程具有安全性和所有權(quán)連接存儲(chǔ)過程可以附加安全證書存儲(chǔ)過程的分類系統(tǒng)存儲(chǔ)過程用戶自定義存儲(chǔ)過程擴(kuò)展存儲(chǔ)過程存儲(chǔ)過程的分類(續(xù))系統(tǒng)存儲(chǔ)過程完成SQLServer2005的許多過來活動(dòng)以sp_開頭物理上存儲(chǔ)在數(shù)據(jù)庫的resource中,邏輯上存在在每個(gè)數(shù)據(jù)庫的SYS框架中存儲(chǔ)過程的分類(續(xù))用戶自定義存儲(chǔ)過程用戶自定義存儲(chǔ)過程是指封裝的由用戶創(chuàng)建、能完成特定功能的、可重用代碼的模塊或例程。擴(kuò)展存儲(chǔ)過程擴(kuò)展存儲(chǔ)過程是指使用編程語言(例如C)創(chuàng)建自己的外部例程,是指MicrosoftSQLServer的實(shí)例可以動(dòng)態(tài)加載和運(yùn)行的DLL。
存儲(chǔ)過程語法格式語法格式:
CREATE[PROC|PROCEDURE]存儲(chǔ)過程名
[{@參數(shù)名稱參數(shù)數(shù)據(jù)類型}[=參數(shù)的默認(rèn)值][OUTPUT]][,...n][WITHENCRYPTION][WITHRECOMPILE]ASsql_statement
參數(shù):@參數(shù)名稱:存儲(chǔ)過程可以沒有參數(shù)。也可以聲明一個(gè)或多個(gè)參數(shù),參數(shù)名稱必須@作為第一個(gè)字符。參數(shù)后面帶OUTPUT,表示為輸出參數(shù)。WITHENCRYPTION:對(duì)存儲(chǔ)過程加密,其他用戶無法查看存儲(chǔ)過程的定義。WITHRECOMPILE:每次執(zhí)行該存儲(chǔ)過程都重新進(jìn)行編譯。sql_statemen:該存儲(chǔ)過程中定義的編程語句。存儲(chǔ)過程的組成存儲(chǔ)過程的定義中包含如下的兩個(gè)主要組成部分。(1)過程名稱及其參數(shù)的說明:包括所有的輸入?yún)?shù)以及傳給調(diào)用者的輸出參數(shù)。(2)過程的主體:也稱為過程體,針對(duì)數(shù)據(jù)庫的操作語句(Transact-SQL語句),包括調(diào)用其它存儲(chǔ)過程的語句。不帶參數(shù)的存儲(chǔ)過程創(chuàng)建不帶參數(shù)的存儲(chǔ)過程語法格式:CREATE[PROC|PROCEDURE]存儲(chǔ)過程名
[WITHENCRYPTION][WITHRECOMPILE]ASsql_statement不帶參數(shù)的存儲(chǔ)過程【例9.1】創(chuàng)建一個(gè)名為Cu_information的存儲(chǔ)過程,用于查詢客戶的信息。
usestudentCREATEPROCEDURECu_informationASSELECT*FROMCustomer不帶參數(shù)的存儲(chǔ)過程(續(xù))
執(zhí)行不帶參數(shù)的存儲(chǔ)過程語法結(jié)構(gòu)如下:EXEC存儲(chǔ)過程名【例9.3】執(zhí)行創(chuàng)建的Cu_Information存儲(chǔ)過程。
EXECCu_Information創(chuàng)建存儲(chǔ)過程的步驟實(shí)現(xiàn)過程體的功能構(gòu)建實(shí)現(xiàn)特定功能的SQL語句創(chuàng)建存儲(chǔ)過程CREATEPROCEDUREASSQL語句集驗(yàn)證準(zhǔn)確性
EXEC<存儲(chǔ)過程名>帶輸入?yún)?shù)的存儲(chǔ)過程創(chuàng)建帶輸入?yún)?shù)的存儲(chǔ)過程CREATE[PROC|PROCEDURE]存儲(chǔ)過程名
[{@參數(shù)名稱參數(shù)數(shù)據(jù)類型}[=參數(shù)的默認(rèn)值][,...n][WITHENCRYPTION][WITHRECOMPILE]ASsql_statement帶輸入?yún)?shù)的存儲(chǔ)過程【例9.4】創(chuàng)建一個(gè)存儲(chǔ)過程,實(shí)現(xiàn)根據(jù)訂單號(hào)獲取該訂單的信息的功能。CREATEPROCEDUREOrderDetail@OrderIDINTASSELECT*FROMSell_OrderWHERESellOrderId=@OrderID帶輸入?yún)?shù)的存儲(chǔ)過程【例9.6】創(chuàng)建名為listEmployee的存儲(chǔ)過程,其功能為:在員工表employee中查找符合性別和超過指定工資條件的員工詳細(xì)信息。CREATEPROCEDURElistEmployee@sexvarchar(2),@salarymoneyASSELECT*FROMemployeeWHEREsex=@sexandsalary>@salary帶輸入?yún)?shù)的存儲(chǔ)過程(續(xù))執(zhí)行輸入?yún)?shù)的存儲(chǔ)過程兩種方法:使用參數(shù)名傳遞參數(shù)值EXEC存儲(chǔ)過程名[@參數(shù)名=參數(shù)值][DEFAULT][,…n]按位置傳遞參數(shù)值EXEC存儲(chǔ)過程名[參數(shù)值1,參數(shù)值2,…]帶輸入?yún)?shù)的存儲(chǔ)過程(續(xù))【例9.7】使用【例9.5】中創(chuàng)建的存儲(chǔ)過程customer_order,獲取“三川實(shí)業(yè)”的信息,包括聯(lián)系人姓名、聯(lián)系方式以及該公司訂購產(chǎn)品的明細(xì)表。代碼如下:EXECcustomer_order@customername='三川實(shí)業(yè)'帶輸入?yún)?shù)的存儲(chǔ)過程(續(xù))【例9.8】利用存儲(chǔ)過程listEmployee,查找工資超過4000元的的男員工和工資超過3000元女員工的詳細(xì)信息。代碼如下:EXEClistEmployee@sex='男',@salary=4000EXEClistEmployee@salary=3500,@sex='女'帶輸入?yún)?shù)的存儲(chǔ)過程(續(xù))【例9.9】按位置傳遞執(zhí)行存儲(chǔ)過程listEmployee,查找工資超過4000元的的男員工和工資超過3000元女員工的詳細(xì)信息。代碼如下:EXEClistEmployee'男',4000EXEClistEmployee'女',3500帶輸入?yún)?shù)的存儲(chǔ)過程(續(xù))【例9.11】利用Name_Employee存儲(chǔ)過程查詢所有員工信息和姓王的員工信息EXECName_Employee查詢所有員工信息EXECName_Employee‘王%’查詢姓王的員工信息帶輸出參數(shù)的存儲(chǔ)過程【例9.12】創(chuàng)建帶返回參數(shù)的存儲(chǔ)過程求兩個(gè)整數(shù)的和。代碼如下:CREATEPROCEDUREPRO_SUM@N1INT,@N2INT,@RESULTINTOUTPUTASSET@RESULT=@N1+@N2帶輸出參數(shù)的存儲(chǔ)過程【例9.13】執(zhí)行【例9.11】創(chuàng)建的PRO_SUM存儲(chǔ)過程。代碼如下:DECLARE@ANSWERINTEXECPRO_SUM20,69,@ANSWEROUTPUTselect@ANSWER'結(jié)果'查看存儲(chǔ)過程sp_help用于顯示存儲(chǔ)過程的參數(shù)及其數(shù)據(jù)類型,語法格式如下:sp_help[[@objname=]存儲(chǔ)過程名]sp_helptext用于顯示存儲(chǔ)過程的源代碼,語法格式如下:sp_helptext[[@objname=]存儲(chǔ)過程]查看存儲(chǔ)過程【例9.14】查看customer_order存儲(chǔ)過程的參數(shù)和數(shù)據(jù)類型。代碼如下:USECompanySalesGOsp_helpcustomer_order查看存儲(chǔ)過程【例9.15】查看customer_order存儲(chǔ)過程的源代碼。代碼如下:USECompanySalesGOsp_helptextcustomer_order刪除用戶存儲(chǔ)過程刪除用戶存儲(chǔ)過程可以使用DROP命令,語法格式如下:DROP{PROC|PROCEDURE}存儲(chǔ)過程名[,...n]刪除用戶存儲(chǔ)過程【例9.16】刪除PRO_SUM存儲(chǔ)過程。代碼如下:USECompanySalesGODROPPROCEDUREPRO_SUM修改存儲(chǔ)過程ALTERPROCEDURE語句的語法格式如下:ALTER[PROC|PROCEDURE]存儲(chǔ)過程名
[{@參數(shù)名稱參數(shù)數(shù)據(jù)類型}[=參數(shù)的默認(rèn)值][OUTPUT]][,...n][WITHENCRYPTION][WITHRECOMPILE]ASsql_statement系統(tǒng)存儲(chǔ)過程常用系統(tǒng)存儲(chǔ)過程:sp_tables:返回可在當(dāng)前環(huán)境中查詢的對(duì)象列表。這代表可在FROM子句中出現(xiàn)的任何對(duì)象。sp_stored_procedures:返回當(dāng)前環(huán)境中的存儲(chǔ)過程列表。sp_rename:在當(dāng)前數(shù)據(jù)庫中更改用戶創(chuàng)建對(duì)象的名稱。此對(duì)象可以是表、索引、列、別名數(shù)據(jù)類型。sp_renamedb:更改數(shù)據(jù)庫的名稱。系統(tǒng)存儲(chǔ)過程sp_help:報(bào)告有關(guān)數(shù)據(jù)庫對(duì)象(sys.sysobjects兼容視圖中列出的所有對(duì)象)、用戶定義數(shù)據(jù)類型或SQLServer2005提供的數(shù)據(jù)類型的信息。sp_helptext:是用戶定義規(guī)則的定義、默認(rèn)值、未加密的Transact-SQL存儲(chǔ)過程、用戶定義Transact-SQL函數(shù)、觸發(fā)器、計(jì)算列、CHECK約束、視圖或系統(tǒng)對(duì)象(如系統(tǒng)存儲(chǔ)過程)。sp_who:提供有關(guān)MicrosoftSQLServerDatabaseEngine實(shí)例中的當(dāng)前用戶和進(jìn)程的信息。sp_password:為MicrosoftSQLServer登錄名添加或更改密碼。擴(kuò)展存儲(chǔ)過程使用外部語言編寫的外部存儲(chǔ)過程,如C語言,通常以動(dòng)態(tài)鏈接庫DLL形式出現(xiàn),擴(kuò)展SQLServer2005功能一般以xp_開頭xp_cmdshell:用來運(yùn)行從命令行執(zhí)行的程序Xp_sscanf:將數(shù)據(jù)從字符串讀入時(shí)每個(gè)格式參
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- DBT29-143-2021 天津市地下鐵道基坑工程施工技術(shù)規(guī)程
- 2025年電動(dòng)工具結(jié)構(gòu)件項(xiàng)目投資可行性研究分析報(bào)告
- 2024-2025學(xué)年高中化學(xué)第一章第二節(jié)原子結(jié)構(gòu)與元素的性質(zhì)第2課時(shí)元素周期律一教案新人教版選修3
- 2024-2025學(xué)年新教材高中化學(xué)第一章章末整合提升教案新人教版必修第一冊(cè)
- 2024-2025學(xué)年高中政治課時(shí)分層作業(yè)5消費(fèi)及其類型含解析新人教版必修1
- 2025年蒸餾單甘酯項(xiàng)目可行性研究報(bào)告
- 2025年4-氯甲基哪酮項(xiàng)目可行性研究報(bào)告
- 2024-2025學(xué)年高中物理第三章牛頓運(yùn)動(dòng)定律第4節(jié)牛頓第三定律課時(shí)作業(yè)含解析教科版必修1
- 2025年雙頭機(jī)械器研磨機(jī)項(xiàng)目投資可行性研究分析報(bào)告-20241226-203722
- 2025年中國無線網(wǎng)橋行業(yè)市場運(yùn)營現(xiàn)狀及投資規(guī)劃研究建議報(bào)告
- 期末 (試題) -2024-2025學(xué)年人教PEP版英語五年級(jí)上冊(cè)
- 專題17 物質(zhì)結(jié)構(gòu)與性質(zhì)綜合題-五年(2020-2024)高考化學(xué)真題分類匯編(解析版)
- 語文學(xué)習(xí)任務(wù)群的解讀及設(shè)計(jì)要領(lǐng)
- 2024年山東省高考生物試卷真題(含答案解析)
- 光伏發(fā)電站項(xiàng)目安全技術(shù)交底資料
- 富血小板血漿(PRP)臨床實(shí)踐與病例分享課件
- 光伏工程施工組織設(shè)計(jì)
- 《護(hù)理科研》課件
- 人教版(2024新版)八年級(jí)上冊(cè)物理《開啟科學(xué)探索之旅》教學(xué)設(shè)計(jì)
- 年產(chǎn)1萬噸的二氧化碳捕集及資源化利用全流程示范項(xiàng)目可行性研究報(bào)告模板-立項(xiàng)拿地
- 部編版語文四年級(jí)下冊(cè)第六單元大單元作業(yè)設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論