登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

秋天

深秋的夜晚

 
 
 

日志

 
 

关于 存储过程返回值  

2009-02-21 19:42:16|  分类: 默认分类 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

有一个表,其主键是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;

  评论这张
 
阅读(2681)| 评论(0)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018