zoukankan
html css js c++ java
aspnet_Profile_DeleteProfiles
ALTER
PROCEDURE
dbo.aspnet_Profile_DeleteProfiles
@ApplicationName
NVARCHAR
(
256
),
@UserNames
NVARCHAR
(
4000
)
AS
BEGIN
DECLARE
@UserName
NVARCHAR
(
256
)
DECLARE
@CurrentPos
INT
DECLARE
@NextPos
INT
DECLARE
@NumDeleted
INT
DECLARE
@DeletedUser
INT
DECLARE
@TranStarted
BIT
DECLARE
@ErrorCode
INT
SET
@ErrorCode
=
0
SET
@CurrentPos
=
1
SET
@NumDeleted
=
0
SET
@TranStarted
=
0
--
---------声明变量并为变量附初值-----------------
IF
(
@@TRANCOUNT
=
0
)
BEGIN
BEGIN
TRANSACTION
SET
@TranStarted
=
1
END
ELSE
SET
@TranStarted
=
0
--
-------------如果当前活动事务为0,开始事务并设置事务参数为1---------------------
WHILE
(
@CurrentPos
<=
LEN
(
@UserNames
))
--
如果@CurrentPos不大于输入参数的长度
/**/
/*
LEN返回给定字符串表达式的字符(而不是字节)个数,其中不包含尾随空格。
*/
BEGIN
SELECT
@NextPos
=
CHARINDEX
(N
'
,
'
,
@UserNames
,
@CurrentPos
)
/**/
/*
CHARINDEX 返回字符串中指定表达式的起始位置
返回@UserNames中从@CurrentPos开始 N',' 的起始位置
*/
IF
(
@NextPos
=
0
OR
@NextPos
IS
NULL
)
SELECT
@NextPos
=
LEN
(
@UserNames
)
+
1
SELECT
@UserName
=
SUBSTRING
(
@UserNames
,
@CurrentPos
,
@NextPos
-
@CurrentPos
)
SELECT
@CurrentPos
=
@NextPos
+
1
/**/
/*
SUBSTRING 返回字符、binary、text 或 image 表达式的一部分。
上面即返回@UserNames中开始位置为@CurrentPos,长度为@NextPos - @CurrentPos的部分
*/
--
--------------------上面这部分有点不明白为什么要这样-----------
IF
(
LEN
(
@UserName
)
>
0
)
BEGIN
SELECT
@DeletedUser
=
0
--
---------------调用存储过程aspnet_Users_DeleteUser(最好看下这个存储过程先),输出参数为@DeletedUser----------
EXEC
dbo.aspnet_Users_DeleteUser
@ApplicationName
,
@UserName
,
4
,
@DeletedUser
OUTPUT
IF
(
@@ERROR
<>
0
)
--
如果存储过程执行有错误,则跳转到回滚
BEGIN
SET
@ErrorCode
=
-
1
GOTO
Cleanup
END
IF
(
@DeletedUser
<>
0
)
--
如果存储过程的输出参数不为0,即成功了,则@NumDeleted递增1
SELECT
@NumDeleted
=
@NumDeleted
+
1
END
END
SELECT
@NumDeleted
--
-查询 NumDeleted
IF
(
@TranStarted
=
1
)
--
-事务运行到此
BEGIN
SET
@TranStarted
=
0
COMMIT
TRANSACTION
--
-结束事务
END
SET
@TranStarted
=
0
RETURN
0
Cleanup:
IF
(
@TranStarted
=
1
)
BEGIN
SET
@TranStarted
=
0
ROLLBACK
TRANSACTION
END
RETURN
@ErrorCode
END
查看全文
相关阅读:
很实用的html meta标签实现页面跳转
oracle 实例名和服务名以及数据库名区别
Oracle 创建 DBLink 的方法
Java (六):java中Math常用方法
Java (四):String,StringBuilder,StringBuffer三者的区别
ROS Learning-001 安装 ROS indigo
Windows cmd 将命令(/指令)写到一个文件里,直接运行这个文件。提高工作效率
Blender 基础 骨架-02 骨架的各种呈现方式
Blender 基础 骨架 01
Python 解决 :NameError: name 'reload' is not defined 问题
原文地址:https://www.cnblogs.com/ruanbl/p/491062.html
最新文章
Aizu 2300 Calender Colors(暴力)
Aizu 2301 Sleeping Time(概率,剪枝)
Aizu 2303 Marathon Match (概率)
UVA 11552 Fewest Flops(区间dp)
UVALive 4794 Sharing Chocolate(状压,枚举子集)
基本数据类型对象包装类
字符串缓冲区
字符串的方法
Eclipse常用快捷键
IO流
热门文章
异常处理
内部类
多态
继承
java 实例之杨辉三角
oracle 疑问
oracle 用户与表空间
oracle 安装(一)
Oracle :备份 、还原数据库
eclipse 与 jre 版本 不匹配
Copyright © 2011-2022 走看看