欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

sql存儲(chǔ)過程幾個(gè)簡(jiǎn)單例子

 更新時(shí)間:2016年02月23日 14:01:09   投稿:mdxy-dxy  
存儲(chǔ)過程是一組為了完成特定功能的SQL語(yǔ)句集,是利用SQL Server所提供的Transact-SQL語(yǔ)言所編寫的程序。經(jīng)編譯后存儲(chǔ)在數(shù)據(jù)庫(kù)中。存儲(chǔ)過程是數(shù)據(jù)庫(kù)中一個(gè)重要的對(duì)象

sql存儲(chǔ)是數(shù)據(jù)庫(kù)操作過程中比較重要的一個(gè)環(huán)節(jié),對(duì)于一些初學(xué)者來(lái)說(shuō)也是比較抽象難理解的,本文我將通過幾個(gè)實(shí)例來(lái)解析數(shù)據(jù)庫(kù)中的sql存儲(chǔ)過程,這樣就將抽象的事物形象化,比較容易理解。

例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:

下面的存儲(chǔ)過程實(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)用該存儲(chǔ)過程,并根據(jù)@LEGAL參數(shù)的值判斷用戶是否合法。

例3:一個(gè)高效的數(shù)據(jù)分頁(yè)的存儲(chǔ)過程 可以輕松應(yīng)付百萬(wàn)數(shù)據(jù)

CREATE PROCEDURE pageTest --用于翻頁(yè)的測(cè)試
--需要把排序字段放在第一列

(
@FirstID nvarchar(20)=null, --當(dāng)前頁(yè)面里的第一條記錄的排序字段的值
@LastID nvarchar(20)=null, --當(dāng)前頁(yè)面里的最后一條記錄的排序字段的值
@isNext bit=null, --true 1 :下一頁(yè);false 0:上一頁(yè)
@allCount int output, --返回總記錄數(shù)
@pageSize int output, --返回一頁(yè)的記錄數(shù)
@CurPage int --頁(yè)號(hào)(第幾頁(yè))0:第一頁(yè);-1最后一頁(yè)。
)

AS

if @CurPage=0--表示第一頁(yè)
begin
--統(tǒng)計(jì)總記錄數(shù)
select @allCount=count(ProductId) from Product_test 

set @pageSize=10
--返回第一頁(yè)的數(shù)據(jù)
select top 10 
ProductId,
ProductName,
Introduction 
from Product_test order by ProductId 
end

else if @CurPage=-1--表示最后一頁(yè)

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
--翻到下一頁(yè)
select top 10 ProductId,
ProductName,
Introduction
from Product_test where ProductId > @LastID order by ProductId 
else
--翻到上一頁(yè)
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存儲(chǔ)過程比較典型的例子,希望大家好好學(xué)習(xí),都能夠?qū)W到大家各自需要的東西。

相關(guān)文章

最新評(píng)論