您的位置:首页 > 其它

关于 存储过程返回值

2008-12-29 16:31 260 查看

有一个表,其主键是int并且为自动增长的。当我向这个表中插入一项并且不提供主键的时候,数据库会自动添加一个唯一的主键。

问题是:

怎么得到刚刚插入的那一项的主键值?

1、

存储过程有两种方式返回值:

第一:通过output 参数

第二:通过return来实现

而在你的存储过程已经声明了一个output参数,只要你在你的存储过程已经给这个值赋值了,它就能返回回去.

建议一般用output参数,因为它可以返回多个,而return只能是一个,return一般用来返回:影响的行数,错误编码等

2、

为避免多用户操作数据库取值不正确

正确应该要这样取:

SELECT * FROM table WHERE (AutoIncreaseColumn = SCOPE_IDENTITY())

3、

SCOPE_IDENTITY、IDENT_CURRENT 和 @@IDENTITY,它们都返回插入到 IDENTITY 列中的值。

IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值。IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。IDENT_CURRENT 返回为任何会话和作用域中的特定表所生成的值。

@@IDENTITY 返回为当前会话的所有作用域中的任何表最后生成的标识值。

SCOPE_IDENTITY 返回为当前会话和当前作用域中的任何表最后生成的标识值

SCOPE_IDENTITY 和 @@IDENTITY 返回在当前会话中的任何表内所生成的最后一个标识值。但是,SCOPE_IDENTITY 只返回插入到当前作用域中的值;@@IDENTITY 不受限于特定的作用域。

IDENT_CURRENT() 始终返回指定表最后插入的标识值

@@IDENTITY 返回当前会话的标识值,无论是否在同一个作用域,在测试1、2中,可以看到它返回的是触发器中插入记录的标识值,而在测试3中,因为当前会话无插入记录,所以返回NULL

SCOPE_IDENTITY() 返回当前会话同一作用域的标识值,所以在测试1、2中,它返回的值不受触发器的影响,而在测试3中,因为当前会话无插入记录,所以返回NULL

4、

插入之后马上 select @@identity from youetable 即可

如果是存储过程可以把@@identity作为插入之后的返回值

5、

在查询分析器中获取存储过程中的return的值

declare @return_value int

set @return_value = 1

exec EXT_SUBJECTINSERT_11

"2006","艰难", "高中",

"语文","问答","知识点","第一期","dd","2006-9-11 8:32:54","重文",

"insert",1,1,

"search","dd","fir",@return_value output

select @return_value

6、

DECLARE @tmpCount int

SET @tmpCount int = (SELECT COUNT(*) FROM 表名 WHERE 你要进行搜索的条件)

IF (@tmpCount = 0)

BEGIN

INSERT 操作

RETURN 1

END

ELSE

BEGIN

RETURN 0

END

存储过程来作,存储过程的写法可以参照上面给出的,但是在程序调用的话就需要使用sqlparameter了,关于它的使用方法,可以在网上找到一堆

然后执行sqlcommand,如果仅仅在程序定义了一个返回值参数(returnvalue)那么执行完(excutenoquery)可以由这个参数来判断,如果在数据库和程序中定义了一个返回值参数(output),那么执行完后也可以由这个参数的值进行判断

7、

用int returnValue = Convert.ToInt32(command.ExecuteScalar());执行sql语句,取得返回值

8、

cmd.Parameters["return_value"].Direction=ParameterDirection.ReturnValue;

本文为转载
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: