• 关于 存储过程返回值


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

  • 相关阅读:
    解决mysql-8.0.18 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
    剑指Offer面试题:28.连续子数组的最大和
    Java BigDecimal
    蓝桥杯 分考场 JAVA
    蓝桥杯 合根植物 JAVA
    蓝桥杯 大臣的旅费 JAVA
    蓝桥杯 危险系数 JAVA
    蓝桥杯 幸运数 JAVA
    【转】对memcached使用的总结和使用场景
    【转】Memcached管理与监控工具----MemAdmin
  • 原文地址:https://www.cnblogs.com/flashicp/p/756722.html
Copyright © 2020-2023  润新知