CREATE PROCEDURE zd_kjjLogin@Id Int output,
@userClass nvarchar(20) output,
@department nvarchar(20) output,
@purview nvarchar(20) output,
@userName nvarchar(20),
@passWord nvarchar(20),
@IP nvarchar(20)AS
if exists(select id from [zd_user_admin] where UserName = @userName and [Password] = @passWord) begin
begin transaction
update [zd_user_admin] set LastLoginTime = getdate(), LastLoginIP = @IP,logins = logins+'a' where UserName = @Username
if @@error<>0 begin
rollback transaction
return -1
end
commit transaction
select @Id=Id,@userClass=userClass,@department=department,@purview=purview from [zd_user_admin] where UserName = @userName
return 0
end
return 1
GO
为什么程序中捕获不到return -1这个值呢?
logins是int型,我有意让它+a,也就是想让它报错,返回-1,但是程序中捕获的却是空值
如果改成+1可以正常返回0或者1DIM MyComm : Set MyComm = Server.CreateObject("ADODB.Command")
with MyComm
.ActiveConnection = Conn
.CommandText = "zd_kjjLogin"
.CommandType = 4
.Prepared = true
.Parameters.append .CreateParameter("RETURN",2,4)
.Parameters.append .CreateParameter("@ID",3,2,4)
.Parameters.append .CreateParameter("@userClass",200,2,20)
.Parameters.append .CreateParameter("@department",200,2,20)
.Parameters.append .CreateParameter("@purview",200,2,20)
.Parameters.append .CreateParameter("@UserName",200,1,20,userName)
.Parameters.append .CreateParameter("@Password",200,1,20,passWord)
.Parameters.append .CreateParameter("@ip",200,1,20,ip)
.Execute
end with response.write MyComm(0)
这是调用程序
@userClass nvarchar(20) output,
@department nvarchar(20) output,
@purview nvarchar(20) output,
@userName nvarchar(20),
@passWord nvarchar(20),
@IP nvarchar(20)AS
if exists(select id from [zd_user_admin] where UserName = @userName and [Password] = @passWord) begin
begin transaction
update [zd_user_admin] set LastLoginTime = getdate(), LastLoginIP = @IP,logins = logins+'a' where UserName = @Username
if @@error<>0 begin
rollback transaction
return -1
end
commit transaction
select @Id=Id,@userClass=userClass,@department=department,@purview=purview from [zd_user_admin] where UserName = @userName
return 0
end
return 1
GO
为什么程序中捕获不到return -1这个值呢?
logins是int型,我有意让它+a,也就是想让它报错,返回-1,但是程序中捕获的却是空值
如果改成+1可以正常返回0或者1DIM MyComm : Set MyComm = Server.CreateObject("ADODB.Command")
with MyComm
.ActiveConnection = Conn
.CommandText = "zd_kjjLogin"
.CommandType = 4
.Prepared = true
.Parameters.append .CreateParameter("RETURN",2,4)
.Parameters.append .CreateParameter("@ID",3,2,4)
.Parameters.append .CreateParameter("@userClass",200,2,20)
.Parameters.append .CreateParameter("@department",200,2,20)
.Parameters.append .CreateParameter("@purview",200,2,20)
.Parameters.append .CreateParameter("@UserName",200,1,20,userName)
.Parameters.append .CreateParameter("@Password",200,1,20,passWord)
.Parameters.append .CreateParameter("@ip",200,1,20,ip)
.Execute
end with response.write MyComm(0)
这是调用程序
@Id Int output,
@userClass nvarchar(20) output,
@department nvarchar(20) output,
@purview nvarchar(20) output,
@userName nvarchar(20),
@passWord nvarchar(20),
@IP nvarchar(20) AS
set nocount on --加这一句
if exists(select id from [zd_user_admin] where UserName = @userName and [Password] = @passWord) begin
begin transaction
update [zd_user_admin] set LastLoginTime = getdate(), LastLoginIP = @IP,logins = logins+'a' where UserName = @Username
if @@error <>0 begin
rollback transaction
select -1
return
end
commit transaction
select @Id=Id,@userClass=userClass,@department=department,@purview=purview from [zd_user_admin] where UserName = @userName
select 0
return
end select 1 GO
因为我从来没有那么用过;
如果存储过程有返回参数值,那么在传入参数时加out 参数,而没有象你那样用
刚查到一个例子
下例检查指定作者所在州的 ID。如果所在的州是加利福尼亚州 (CA),将返回状态代码 1。否则,对于任何其它情况(state 的值是 CA 以外的值或者 au_id 没有匹配的行),将返回状态代码 2。CREATE PROCEDURE checkstate @param varchar(11)
AS
IF (SELECT state FROM authors WHERE au_id = @param) = 'CA'
RETURN 1
ELSE
RETURN 2下例显示从 checkstate 执行中返回的状态。第一个显示的是在加利福尼亚州的作者;第二个显示的是不在加利福尼亚州的作者,第三个显示的是无效的作者。必须先声明 @return_status 局部变量后才能使用它。DECLARE @return_status int
EXEC @return_status = checkstate '172-32-1176'
SELECT 'Return Status' = @return_status
GO
@Username
if @@error <>0 begin
rollback transaction
return -1 你都回滚了这么能执行到下一句啊?
@userClass nvarchar(20) output,
@department nvarchar(20) output,
@purview nvarchar(20) output,
@userName nvarchar(20),
@passWord nvarchar(20),
@IP nvarchar(20) AS if exists(select id from [zd_user_admin] where UserName = @userName and [Password] = @passWord) begin
begin transaction
update [zd_user_admin] set LastLoginTime = getdate(), LastLoginIP = @IP,logins = logins+'a' where UserName = @Username
if @@error <>0 begin
--捕获错误一般是这样的。
--加这一句,在前台程序可以捕捉到。
raiserror('这里写上你的错误提示',16,1)
--******************************************
rollback transaction
return -1
end
commit transaction
select @Id=Id,@userClass=userClass,@department=department,@purview=purview from [zd_user_admin] where UserName = @userName
return 0
end return 1
使用 RAISERROR与 PRINT 相比,RAISERROR 在把消息返回给应用程序方面的功能更强大。RAISERROR 能以下列方式中的任意一种返回消息: 已通过 sp_addmessage 系统存储过程添加到 master.dbo.sysmessages 上的由用户定义的错误信息。
在 RAISERROR 语句中指定的消息字符串。
RAISERROR 也有 PRINT 功能的一些扩展: RAISERROR 能够指派一个特定的错误号、严重度和状态。
RAISERROR 能够请求将错误记入 Microsoft® SQL Server™ 2000 错误日志和 Microsoft Windows NT® 应用程序日志中。
消息字符串可以包含替代变量和参量,这与 C 语言中的 printf 功能相似。
当 RAISERROR 在sysmessages 中与用户定义消息的 msg_id 一同使用时,msg_id 被作为 SQL Server 的错误号码或本机错误代码返回。而当 RAISERROR 与 msg_str 而不是 msg_id 一同使用时,返回的 SQL Server 的错误号和本机错误号为 50000。当使用 RAISERROR 返回一个用户定义的错误信息时,在每个引用该错误的 RAISERROR 中使用不同的状态号码。这可以在发生错误时帮助进行错误诊断。 RAISERROR 可以帮助我们发现并解决 Transact-SQL 代码中的问题、检查数据值或返回包含变量文本的消息。下面的示例在返回给应用程序的消息中替换了 DB_ID 和 DB_NAME 函数的值:DECLARE @DBID INT
SET @DBID = DB_ID()DECLARE @DBNAME NVARCHAR(128)
SET @DBNAME = DB_NAME()RAISERROR
('The current database ID is:%d, the database name is: %s.',
16, 1, @DBID, @DBNAME)而以下示例使用由用户定义的消息完成了同样的处理:sp_addmessage 50005, 16,
'The current database ID is:%d, the database name is: %s.'
GO
DECLARE @DBID INT
SET @DBID = DB_ID()DECLARE @DBNAME NVARCHAR(128)
SET @DBNAME = DB_NAME()RAISERROR (50005, 16, 1, @DBID, @DBNAME)
GO第二个 RAISERROR 示例显示,替换参数可以在由用户定义的错误中指定,并且当 RAISERROR 语句执行时由替换参变量填充。