sql存儲(chǔ)過程幾個(gè)簡(jiǎn)單例子
sql存儲(chǔ)是數(shù)據(jù)庫(kù)操作過程中比較重要的一個(gè)環(huán)節(jié),對(duì)于一些初學(xué)者來說也是比較抽象難理解的,本文我將通過幾個(gè)實(shí)例來解析數(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)付百萬數(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到大家各自需要的東西。
- SqlServer 2000、2005分頁(yè)存儲(chǔ)過程整理
- sqlserver存儲(chǔ)過程語法詳解
- SqlServer獲取存儲(chǔ)過程返回值的實(shí)例
- sqlserver 各種判斷是否存在(表名、函數(shù)、存儲(chǔ)過程等)
- sqlserver 存儲(chǔ)過程帶事務(wù) 拼接id 返回值
- sqlserver 存儲(chǔ)過程動(dòng)態(tài)參數(shù)調(diào)用實(shí)現(xiàn)代碼
- sqlserver 存儲(chǔ)過程分頁(yè)(按多條件排序)
- sqlserver 存儲(chǔ)過程分頁(yè)代碼
- sqlserver 常用存儲(chǔ)過程集錦
- sqlserver 通用分頁(yè)存儲(chǔ)過程
- 在SQLServer 2005中編寫存儲(chǔ)過程
- SQLServer 2005 列所有存儲(chǔ)過程的語句
- 分頁(yè) SQLServer存儲(chǔ)過程
相關(guān)文章
詳解SQL Server數(shù)據(jù)庫(kù)鏈接查詢的方式
本文我們主要介紹了SQL Server數(shù)據(jù)庫(kù)鏈接查詢的方式,包括內(nèi)連接、外連接和交叉連接等的內(nèi)容,需要的朋友可以參考下2015-08-08
用戶"sa"登陸失敗 SQLServer 錯(cuò)誤18456的解決方法
sqlserver下用sa登錄提示18456錯(cuò)誤的解決方法。2009-11-11
SQL Server數(shù)據(jù)庫(kù)附加失敗的解決辦法
這篇文章主要為大家詳細(xì)介紹了SQL Server數(shù)據(jù)庫(kù)附加失敗,錯(cuò)誤3415、錯(cuò)誤5120的解決辦法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
SQL Server 2005 創(chuàng)建簡(jiǎn)單的存儲(chǔ)過程--總結(jié)分析
本篇文章是對(duì)使用SQL Server 2005創(chuàng)建簡(jiǎn)單的存儲(chǔ)過程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
sql lite 數(shù)據(jù)庫(kù)之間表復(fù)制的方法
最近用sql lite數(shù)據(jù)庫(kù),因?yàn)閿?shù)據(jù)庫(kù)版本的問題,導(dǎo)致數(shù)據(jù)庫(kù)中的數(shù)據(jù)表內(nèi)容不同步,所以需要整合二個(gè)數(shù)據(jù)庫(kù)中的對(duì)應(yīng)表及其表中數(shù)據(jù)。2013-04-04
sqlserver查詢?nèi)サ糁貜?fù)數(shù)據(jù)的實(shí)現(xiàn)
這篇文章主要介紹了sqlserver查詢?nèi)サ糁貜?fù)數(shù)據(jù)的實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01
精妙的SQL和SQL SERVER 與ACCESS、EXCEL的數(shù)據(jù)導(dǎo)入導(dǎo)出轉(zhuǎn)換
sqlserver 與access,excel互相導(dǎo)入導(dǎo)出代碼2008-03-03
揭秘SQL Server 2014有哪些新特性(4)-原生備份加密
SQL Server原聲備份加密對(duì)數(shù)據(jù)安全提供了非常好的解決方案。使用原生備份加密基本不會(huì)增加備份文件大小,并且打破了使用透明數(shù)據(jù)加密后幾乎沒有壓縮率的窘境。2014-08-08
sqlserver清空service broker中的隊(duì)列的語句分享
在我們開發(fā)service broker應(yīng)用時(shí)候,可能用于測(cè)試或者客戶端沒有配置正確等導(dǎo)致服務(wù)端隊(duì)列存在很多垃圾隊(duì)列,不便于我們排查錯(cuò)誤,我們可以使用SQL腳本來清空服務(wù)端這些垃圾數(shù)據(jù)2011-08-08
SQL語句優(yōu)化提高數(shù)據(jù)庫(kù)性能
為了獲得穩(wěn)定的執(zhí)行性能,SQL語句越簡(jiǎn)單越好。對(duì)復(fù)雜的SQL語句,要設(shè)法對(duì)之進(jìn)行簡(jiǎn)化,本文給大家介紹優(yōu)化SQL語句提高數(shù)據(jù)庫(kù)性能,對(duì)sql語句優(yōu)化性能優(yōu)化相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-01-01

