新聞中心
導(dǎo)讀:sql存儲是數(shù)據(jù)庫操作過程中比較重要的一個(gè)環(huán)節(jié),對于一些初學(xué)者來說也是比較抽象難理解的,本文我將通過幾個(gè)實(shí)例來解析數(shù)據(jù)庫中的sql存儲過程,這樣就將抽象的事物形象化,比較容易理解。

創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括當(dāng)陽網(wǎng)站建設(shè)、當(dāng)陽網(wǎng)站制作、當(dāng)陽網(wǎng)頁制作以及當(dāng)陽網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,當(dāng)陽網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到當(dāng)陽省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
例1:
create proc proc_stu
@sname varchar(20),
@pwd varchar(20)
as
select * from ren where sname=@sname and pwd=@pwd
go
查看結(jié)果:proc_stu 'admin','admin'
例2:
下面的存儲過程實(shí)現(xiàn)用戶驗(yàn)證的功能,如果不成功,返回0,成功則返回1.
CREATE PROCEDURE VALIDATE @USERNAME CHAR(20),@PASSWORD CHAR(20),@LEGAL BIT OUTPUT
AS
IF EXISTS(SELECT * FROM REN WHERE SNAME = @USERNAME AND PWD = @PASSWORD)
SELECT @LEGAL = 1
ELSE
SELECT @LEGAL = 0
在程序中調(diào)用該存儲過程,并根據(jù)@LEGAL參數(shù)的值判斷用戶是否合法。
例3:一個(gè)高效的數(shù)據(jù)分頁的存儲過程 可以輕松應(yīng)付百萬數(shù)據(jù)
CREATE PROCEDURE pageTest --用于翻頁的測試
--需要把排序字段放在***列
(
@FirstID nvarchar(20)=null, --當(dāng)前頁面里的***條記錄的排序字段的值
@LastID nvarchar(20)=null, --當(dāng)前頁面里的***一條記錄的排序字段的值
@isNext bit=null, --true 1 :下一頁;false 0:上一頁
@allCount int output, --返回總記錄數(shù)
@pageSize int output, --返回一頁的記錄數(shù)
@CurPage int --頁號(第幾頁)0:***頁;-1***一頁。
)
AS
if @CurPage=0--表示***頁
begin
--統(tǒng)計(jì)總記錄數(shù)
select @allCount=count(ProductId) from Product_test
set @pageSize=10
--返回***頁的數(shù)據(jù)
select top 10
ProductId,
ProductName,
Introduction
from Product_test order by ProductId
end
else if @CurPage=-1--表示***一頁
select * from
(select top 10 ProductId,
ProductName,
Introduction
from Product_test order by ProductId desc ) as aa
order by ProductId
else
begin
if @isNext=1
--翻到下一頁
select top 10 ProductId,
ProductName,
Introduction
from Product_test where ProductId > @LastID order by ProductId
else
--翻到上一頁
select * from
(select top 10 ProductId,
ProductName,
Introduction
from Product_test where ProductId < @FirstID order by ProductId desc) as bb order by ProductId
end
上文中講到的這三個(gè)例子都是sql存儲過程比較典型的例子,希望大家好好學(xué)習(xí),都能夠?qū)W到大家各自需要的東西。
【編輯推薦】
- sql server中表的介紹
- mSQL數(shù)據(jù)庫的技術(shù)特點(diǎn)點(diǎn)評
- sql 2000修復(fù)步驟
名稱欄目:sql存儲過程幾個(gè)簡單例子(一)
分享鏈接:http://fisionsoft.com.cn/article/cdephjp.html


咨詢
建站咨詢
