数据库中有自增字段UID

存储过程如下:

CREATE     PROCEDURE   AddUser   
(   
@Username           nvarchar(50),   
@Email         nvarchar(100),   
@Password   nvarchar(50),   
@UserID       int   OUTPUT   
)   
AS   
INSERT   INTO   Users   
(  Username, Email, Password  )     
  VALUES   
  (  @Username,  @Email,  @Password   
  )   
  SELECT   
          @UserID   =   @@Identity   
  GO

程序如下:
SqlCommand cmd=new SqlCommand("AddUser",conn);
cmd.CommandType=CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@Username",Username));
cmd.Parameters.Add(new SqlParameter("@Email",Email));
cmd.Parameters.Add(new SqlParameter("@Password",Password));

SqlParameter outPara = new SqlParameter("@UserID", SqlDbType.Int);
outPara.Direction = ParameterDirection.Output;
cmd.Parameters.Add(outPara);

if (cmd.ExecuteNonQuery() > -1)
{
if (outPara.Value is int)
{
int retValue = (int)outPara.Value;
}
}
CMD执行

int UID;
UID = cmd.Parameters["@userid"];

2、
SqlParameter.Direction 属性
获取或设置一个值,该值指示参数是只可输入、只可输出、双向还是存储过程返回值参数。

属性值
ParameterDirection 值之一。默认为 Input。 
 Input 参数是输入参数。  
 InputOutput 参数既能输入,也能输出。  
 Output 参数是输出参数。  
 ReturnValue 参数表示诸如存储过程、内置函数或用户定义函数之类的操作的返回值。

3、
CREATE   PROCEDURE   [dbo].[ProgrammeDetail   Add]     
  @Beginning_Date   DateTime   ,   
  @Ending_Date   DateTime,   
  @currentID   varchar(10)     out   
    
  AS   
  BEGIN   
  begin   tran   
  insert   into   ProgrammeDetail(BeginTime,EndTime)   values(   @Beginning_Date,@Ending_Date)   
  select   @currentID=max(ProgrammeID)     from   ProgrammeDetail     
  commit   
  return   @currentID   
  END   
  GO

——————————————————————————
--------------------------------------------   
  假设有存储过程如下:   
  ---------------------------------------------   
    
  CREATE   proc   sp_uptmp   @tmpName   varchar(50),@srcPos   varchar(255)   
  as   
    
  Begin   TRAN   
            insert   into   t_template   values(@tmpName,@srcPos)   
  COMMIT       
    
  return   isnull(@@identity,0)   
  GO   
    
    
  ------------------------------------------------------------   
  在   ado.net   里面获取返回值的方法为(c#):   
  ------------------------------------------------------------   
        SqlConnection   dbconn   =   new   SqlConnection(connStr);   
        SqlCommand   cmd   =   new   SqlCommand("sp_uptmp",dbconn);   
        cmd.CommandType   =   CommandType.StoredProcedure;   
    
        SqlParameter   tmpName   =   cmd.Parameters.Add("@tmpName",SqlDbType.VarChar);   
        SqlParameter   srcPos   =   _cmd.Parameters.Add("@srcPos",SqlDbType.VarChar);   
        SqlParameter   rtnval   =   cmd.Parameters.Add("rval",SqlDbType.Int);   
    
        tmpName.Direction   =   ParameterDirection.Input;   
        srcPos.Direction   =   ParameterDirection.Input;   
        rtnval.Direction   =   ParameterDirection.ReturnValue;   
    
        tmpName.Value   =   "";   
        srcPos.Value   =   "";   
        dbconn.Open();   
        cmd.ExecuteNonQuery();   
        dbconn.Close();   
    
        tmpid   =   (int)rtnval.Value;     //此处即为返回值   
3、
存储过程:   
    
  create   procedure   AddRecord   
  (@field1   varchar(20),   
  @field2   varchar(30))   
  as   
  insert   into   mytable(field1,field2)   values(@field1,@field2)   
  select   @@identity   
  go   
    
  在asp.net程序中这样调用存储过程:   
    
  SqlConnection   conn=....//连接字符串   
  SqlCommand   cmd=new   SqlCommand("AddRecord",conn);   
  cmd.CommandType=CommandType.StoredProcedure;
  cmd.Parameters.Add("@field1","field1的值");   
  cmd.Parameters.Add("@field2","field2的值");   
  conn.Open();   
  int   iKey=(int)cmd.ExecuteScalar();   
  conn.Close();   
    
  最后的iKey就是你要的刚插入的主键值。

存储过程中得到新增数据的ID的更多相关文章

  1. ssm mysql 新增数据返回id

    描述: 在ssm项目中,新增一条数据,返回该数据的数据库id(主键) 实现方法: 1.xml 增加  useGeneratedKeys="true" keyProperty=&qu ...

  2. Thinkphp5.0 获取新增数据的ID

    // 方法1 insertGetId方法新增数据并返回主键值使用getLastInsID方法: Db::name('user')->insert($data); $userId = Db::na ...

  3. Oracle 存储过程中的临时表数据自动清空

    问题叙述: 用 EXECUTE IMMEDIATE 动态往临时表插入数据,跟踪发现插入临时表后数据会立马清空,按理说等存储过程执行完才会清空临时表才对,现在是执行插入语句后下一步验证就发现临时表就没有 ...

  4. 创建触发器在表中播入数据时ID自动增长

    ),age )) create or replace trigger gger_tt before insert on ttt for each row when (new.id is null) b ...

  5. sql server中新增一条数据后返回该数据的ID

    开发中遇到的问题:在新增一条数据后往往不需要返回该数据的ID,但是有的时候可能需要返回该数据的ID以便后面的编程使用. 在这里介绍两种方法: 其一:使用存储过程: create procedure a ...

  6. 将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据

    领导让在存储过程中批量添加数据,找出效率最高的,我看到后台代码后,发现可以将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据,知道还有其 ...

  7. 使用Hibernate框架,新增数据后如何返回新增数据的全部信息

    一.需求描述:一个修改事物(TRANSACTION)先后包括子事物修改和子事物新增,修改事物完成后返回其子事物新增的全部数据  二.实现:若实现修改对象后还需要新增一个新对象,并返回新对象的需求,保存 ...

  8. [转]SQLSERVER存储过程调用不同数据库的数据_存储过程中通过链接服务器访问远程服务器

    本文转自:http://blog.csdn.net/nnaabbcc/article/details/7967761 存储过程调用不同数据库的数据 在存储过程调用不同数据库的数据该如何做,比如在存储过 ...

  9. 代码中添加事务控制 VS(数据库存储过程+事务) 保证数据的完整性与一致性

    做人事档案的系统考虑到数据的安全性与一致性,毕竟是要对外上线.真正投入使用的项目,数据库的可靠性与安全性上我们开发人员要考虑的就很多了,记得做机房收费系统时注册新卡是自己为了简单,写成了一个存储过程( ...

随机推荐

  1. PHP反射获取当前函数的内容

    <?php $test = function () { echo 'hello world'; }; function closure_dump($closure) { try { $func ...

  2. 使用winsound模块播放声音

    import winsound import math s = """3345 1233345 234 431 434 -612 12334567 +1+1345 234 ...

  3. Python学习笔记020——数据库知识概述

    数据库概述 1 提供数据库的软件都有哪些 MySQL.SQL_Server.Oracle.DB2.Mariadb.MongoDB ... (1)是否开源 开源软件:MySQL.Mariadb.Mong ...

  4. 消息队列实现回射客户/服务器和 msgsnd、msgrcv 函数

    一.msgsnd 和 msgrcv 函数 #include <sys/types.h>   #include <sys/ipc.h>   #include <sys/ms ...

  5. 关于父进程和子进程的关系(UAC 绕过思路)

    表面上看.在windows中. 假设是a进程创建了b进程,那么a进程就是b进程的父进程.反之,假设是b创建了a,那么b进程就是a的父进程,这是在windows出现以来一直是程序员们都证实的,可是在在w ...

  6. NYOJ239 月老的难题 【二分图最大匹配&#183;匈牙利】

    月老的难题 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描写叙述 月老准备给n个女孩与n个男孩牵红线.成就一对对美好的姻缘. 如今,因为一些原因,部分男孩与女孩可能结成幸福 ...

  7. django post和get 比较

    当我们提交表单仅仅需要获取数据时就可以用GET: 而当我们提交表单时需要更改服务器数据的状态,或者说发送e-mail,或者其他不仅仅是获取并显示数据的时候就使用POST. 在这个搜索书籍的例子里,我们 ...

  8. java刚開始学习的人常见的问题

    ){                out.write(c);            }        }finally{            if(in!=null){              ...

  9. [Jobdu] 题目1214:丑数

    题目描述: 把只包含因子2.3和5的数称作丑数(Ugly Number).例如6.8都是丑数,但14不是,因为它包含因子7.习惯上我们把1当做是第一个丑数.求按从小到大的顺序的第N个丑数. 输入: 输 ...

  10. (转) 共享个很棒的vim配置

    发现了一个很棒的vim配置方法,现在共享给大家. https://github.com/kepbod/ivim   ivim - The Vim Distribution of Xiao-Ou Zha ...