新聞中心
如果需要讓SQL數(shù)據(jù)庫(kù)中的事務(wù)和存儲(chǔ)過(guò)程優(yōu)化,SQL語(yǔ)句應(yīng)該如何寫(xiě)呢?下面就將為您介紹存儲(chǔ)過(guò)程優(yōu)化的SQL語(yǔ)句寫(xiě)法,希望對(duì)您學(xué)習(xí)SQL語(yǔ)句的使用有所幫助。

創(chuàng)新互聯(lián)專(zhuān)業(yè)為企業(yè)提供雷山網(wǎng)站建設(shè)、雷山做網(wǎng)站、雷山網(wǎng)站設(shè)計(jì)、雷山網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、雷山企業(yè)網(wǎng)站模板建站服務(wù),十年雷山做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
判斷插入值是否重復(fù):
事務(wù)和存儲(chǔ)過(guò)程優(yōu)化
CREATE PROCEDURE IR_rb_User_UpdateUser
(
@UserID int,
@Name nvarchar(50),
@Email nvarchar(100),
@Password nvarchar(20),
@RoleID int,
@iSuccess int output
)
AS
set @iSuccess = -1 --判斷是否成功有錯(cuò)誤應(yīng)為插入重復(fù)鍵
IF EXISTS (SELECT Email FROM rb_Users WHERE Email = @Email and UserID<>@UserID)
BEGIN
set @iSuccess = -2
return
END
BEGIN TRAN
UPDATE rb_Users SET Name = @Name, Email = @Email, Password = @Password WHERE UserID = @UserID
IF @@ERROR <> 0
BEGIN
ROLLBACK TRAN
return
END
set @iSuccess = -3
update rb_UserRoles set RoleID=@RoleID where UserID=@UserID
IF @@ERROR <> 0
BEGIN
ROLLBACK TRAN
return
END
COMMIT TRAN
set @iSuccess = 1
GO
條件查詢(xún)語(yǔ)句:
條件查詢(xún)直接放在SQL中判斷
CREATE PROCEDURE IR_SysAuthorization_GetAllSysAuthorization
(
@Type int,
@UserID varchar(20)
)
AS
declare @strsql varchar(1500) --臨時(shí)sql語(yǔ)句
declare @strwhere varchar(1000) --臨時(shí)sql的條件語(yǔ)句
set @strsql = ''
set @strsql = @strsql + 'select UserID,Role,(select typename from SysAuthorizationType where type=t.type) as typeTmp, '
set @strsql = @strsql + '(CASE WHEN State = 1 THEN ' + '''有效''' + ' ELSE ' + '''無(wú)效''' + ' END) AS StateTmp '
set @strsql = @strsql + 'FROM SysAuthorization t '
set @strwhere = ''
IF @UserID <> ''
BEGIN
set @strwhere = @strwhere + ' and (UserID LIKE ' + '''' + '%' + @UserID + '%' + '''' + ')'
END
IF @Type >0
BEGIN
set @strwhere = @strwhere + ' and Type = ' + CAST(@Type AS varchar(12))
END
if @strwhere <>''
BEGIN
set @strsql = @strsql + ' where ' + right(@strwhere, len(@strwhere)-4)
END
--按用戶(hù)名排序
set @strsql = @strsql + ' ORDER BY Type,UserID'
exec (@strsql)
GO
本文名稱(chēng):存儲(chǔ)過(guò)程優(yōu)化的SQL語(yǔ)句寫(xiě)法
URL分享:http://m.5511xx.com/article/coeeohs.html


咨詢(xún)
建站咨詢(xún)
