午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    SQL Server數(shù)據(jù)庫中的存儲過程介紹
    來源:易賢網(wǎng) 閱讀:869 次 日期:2015-03-03 10:06:51
    溫馨提示:易賢網(wǎng)小編為您整理了“SQL Server數(shù)據(jù)庫中的存儲過程介紹”,方便廣大網(wǎng)友查閱!

    什么是存儲過程

    如果你接觸過其他的編程語言,那么就好理解了,存儲過程就像是方法一樣。

    竟然他是方法那么他就有類似的方法名,方法要傳遞的變量和返回結(jié)果,所以存儲過程有存儲過程名有存儲過程參數(shù)也有返回值。

    存儲過程的優(yōu)點:

    存儲過程的能力大大增強了SQL語言的功能和靈活性。

    1.可保證數(shù)據(jù)的安全性和完整性。

    2.通過存儲過程可以使沒有權(quán)限的用戶在控制之下間接地存取數(shù)據(jù)庫,從而保證數(shù)據(jù)的安全。

    3.通過存儲過程可以使相關(guān)的動作在一起發(fā)生,從而可以維護數(shù)據(jù)庫的完整性。

    4.在運行存儲過程前,數(shù)據(jù)庫已對其進行了語法和句法分析,并給出了優(yōu)化執(zhí)行方案。這種已經(jīng)編譯好的過程5.可極大地改善SQL語句的性能。

    6.可以降低網(wǎng)絡(luò)的通信量。

    7.使體現(xiàn)企業(yè)規(guī)則的運算程序放入數(shù)據(jù)庫服務(wù)器中,以便 集中控制。

    存儲過程可以分為系統(tǒng)存儲過程、擴展存儲過程和用戶自定義的存儲過程

    系統(tǒng)存儲過程

    我們先來看一下系統(tǒng)存儲過程,系統(tǒng)存儲過程由系統(tǒng)定義,主要存放在MASTER數(shù)據(jù)庫中,名稱以"SP"開頭或以"XP"開頭。盡管這些系統(tǒng)存儲過程在MASTER數(shù)據(jù)庫中,

    但我們在其他數(shù)據(jù)庫還是可以調(diào)用系統(tǒng)存儲過程。有一些系統(tǒng)存儲過程會在創(chuàng)建新的數(shù)據(jù)庫的時候被自動創(chuàng)建在當(dāng)前數(shù)據(jù)庫中。

    常用系統(tǒng)存儲過程有:

    代碼如下:

    exec sp_databases; --查看數(shù)據(jù)庫

    exec sp_tables; --查看表

    exec sp_columns student;--查看列

    exec sp_helpIndex student;--查看索引

    exec sp_helpConstraint student;--約束

    exec sp_helptext 'sp_stored_procedures';--查看存儲過程創(chuàng)建定義的語句

    exec sp_stored_procedures;

    exec sp_rename student, stuInfo;--更改表名

    exec sp_renamedb myTempDB, myDB;--更改數(shù)據(jù)庫名稱

    exec sp_defaultdb 'master', 'myDB';--更改登錄名的默認數(shù)據(jù)庫

    exec sp_helpdb;--數(shù)據(jù)庫幫助,查詢數(shù)據(jù)庫信息

    exec sp_helpdb master;

    exec sp_attach_db --附加數(shù)據(jù)庫

    exec sp_detach_db --分離數(shù)據(jù)庫

    存儲過程語法:

    在創(chuàng)建一個存儲過程前,先來說一下存儲過程的命名,看到好幾篇講存儲過程的文章都喜歡在創(chuàng)建存儲過程的時候加一個前綴,養(yǎng)成在存儲過程名前加前綴的習(xí)慣很重要,雖然這只是一件很小的事情,但是往往小細節(jié)決定大成敗??吹接械娜讼矚g這樣加前綴,例如proc_名字。也看到這加樣前綴usp_名字。前一種proc是procedure的簡寫,后一種sup意思是user procedure。我比較喜歡第一種,那么下面所有的存儲過程名都以第一種來寫。至于名字的寫法采用駱駝命名法。

    創(chuàng)建存儲過程的語法如下:

    代碼如下:

    CREATE PROC[EDURE] 存儲過程名

    @參數(shù)1 [數(shù)據(jù)類型]=[默認值] [OUTPUT]

    @參數(shù)2 [數(shù)據(jù)類型]=[默認值] [OUTPUT]

    AS

    SQL語句

    EXEC 過程名[參數(shù)]

    使用存儲過程實例:

    1.不帶參數(shù)

    代碼如下:

    create procedure proc_select_officeinfo--(存儲過程名)

    as select Id,Name from Office_Info--(sql語句)

    exec proc_select_officeinfo--(調(diào)用存儲過程)

    2.帶輸入?yún)?shù)

    代碼如下:

    create procedure procedure_proc_GetoffinfoById --(存儲過程名)

    @Id int--(參數(shù)名 參數(shù)類型)

    as select Name from dbo.Office_Info where語句)

    exec procedure_proc_GetoffinfoById 2--(存儲過程名稱之后,空格加上參數(shù),多個參數(shù)中間以逗號分隔)

    注:參數(shù)賦值是,第一個參數(shù)可以不寫參數(shù)名稱,后面?zhèn)魅雲(yún)?shù),需要明確傳入的是哪個參數(shù)名稱

    3.帶輸入輸出參數(shù)

    代碼如下:

    create procedure proc_office_info--(存儲過程名)

    @Id int,@Name varchar(20) output--(參數(shù)名 參數(shù)類型)傳出參數(shù)要加上output

    as

    begin

    select @Name=Name from dbo.Office_Info where --(sql語句)

    end

    declare @houseName varchar(20) --聲明一個變量,獲取存儲過程傳出來的值

    exec proc_office_info--(存儲過程名)

    4,@houseName output--(傳說參數(shù)要加output 這邊如果用@變量 = OUTPUT會報錯,所以換一種寫法)

    select @houseName--(顯示值)

    4.帶返回值的

    代碼如下:

    create procedure proc_office_info--(存儲過程名)

    @Id int--(參數(shù)名 參數(shù)類型)

    as

    begin

    if(select Name from dbo.Office_Info where --(sql語句)

    begin

    return -1

    end

    else

    begin

    return 1

    end

    end

    declare @house varchar(20) --聲明一個變量,獲取存儲過程傳出來的值

    exec @house=proc_office_info 2 --(調(diào)用存儲過程,用變量接收返回值)

    --注:帶返回值的存儲過程只能為int類型的返回值

    print @house

    更多信息請查看IT技術(shù)專欄

    更多信息請查看數(shù)據(jù)庫
    易賢網(wǎng)手機網(wǎng)站地址:SQL Server數(shù)據(jù)庫中的存儲過程介紹
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報警專用圖標(biāo)