日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

sql 存储过程

發(fā)布時間:2025/10/17 编程问答 11 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sql 存储过程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉自:http://www.cnblogs.com/jiajiayuan/archive/2011/06/15/2081201.html

什么是存儲過程呢?
存儲過程就是作為可執(zhí)行對象存放在數據庫中的一個或多個SQL命令。
通俗來講:存儲過程其實就是能完成一定操作的一組SQL語句。

那為什么要用存儲過程呢?
1.存儲過程只在創(chuàng)造時進行編譯,以后每次執(zhí)行存儲過程都不需再重新編譯,而一般SQL語句每執(zhí)行一次就編譯一次,所以使用存儲過程可提高數據庫執(zhí)行速度。
2.當對數據庫進行復雜操作時,可將此復雜操作用存儲過程封裝起來與數據庫提供的事務處理結合一起使用。
3.存儲過程可以重復使用,可減少數據庫開發(fā)人員的工作量。
4.安全性高,可設定只有某些用戶才具有對指定存儲過程的使用權

那存儲過程怎么用呢?
以下通過表Student 來了解存儲過程,因為是要了解存儲過程的簡單用法,所以所有例子均很簡單。

無參數存儲過程:
選出Student表中的所有信息,

create proc StuProc
as //此處 as 不可以省略不寫
begin //begin 和 end 是一對,不可以只寫其中一個,但可以都不寫
select S#,Sname,Sage,Ssex from student
end
go

有參數存儲過程:
全局變量
全局變量也稱為外部變量,是在函數的外部定義的,它的作用域為從變量定義處開始,到本程序文件的末尾。

選出指定姓名的學生信息:

create proc StuProc
@sname varchar(100)
as
begin
select S#,Sname,Sage,Ssex from student where sname=@sname
end
go

exec StuProc '趙雷'//執(zhí)行語句

上面是在外部給變量賦值,也可以在內部直接給變量設置默認值

create proc StuProc
@sname varchar(100)='趙雷'
as
begin
select S#,Sname,Sage,Ssex from student where sname=@sname
end
go

exec StuProc

也可以把變量的內容輸出,使用output

create proc StuProc
@sname varchar(100),
@IsRight int output //傳出參數
as
if exists (select S#,Sname,Sage,Ssex from studentwhere sname=@sname)
set @IsRight =1
else
set @IsRight=0
go

declare @IsRight int
exec StuProc '趙雷' , @IsRight output
select @IsRight

以上是全局變量,下面來了解局部變量
局部變量也稱為內部變量。局部變量是在函數內作定義說明的。其作用域僅限于函數內部,離開該函數后再使用這種變量是非法的。
局部變量的定義:必須先用Declare命令定以后才可以使用,declare{@變量名 數據類型}
局部變量的賦值方法:set{@變量名=表達式}或者select{@變量名=表達式}
局部變量的顯示:select @變量名

create proc StuProc
as
declare @sname varchar(100)
set @sname='趙雷'
select S#,Sname,Sage,Ssex from student where sname=@sname
go

exec StuProc

那如果是要把局部變量的數據顯示出來怎么辦呢?

create proc StuProc
as
declare @sname varchar(100)
set @sname=(select Sname from student where S#=01)
select @sname
go

exec StuProc

本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,并在文章頁面明顯位置以超鏈接形式注明出處,否則保留追究法律責任的權利。

創(chuàng)建這樣的存儲過程有什么用呢,不是只能在數據中查看賽。

我們在做web或者winform 程序,假設需要個登錄,好,我們可以調用用這個存儲過程來登錄,根據傳入的參數,如果查詢出來有記錄,那么這條記錄在數據庫中存在,表示登錄成功,否則失敗。

這樣做的目的更加安全,可以防止sql注入。


總結

以上是生活随笔為你收集整理的sql 存储过程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。