首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >执行Insert命令,在Sql中返回插入的Id

执行Insert命令,在Sql中返回插入的Id
EN

Stack Overflow用户
提问于 2013-08-22 14:46:34
回答 5查看 309.6K关注 0票数 130

我正在使用MVC4中的C#将一些值插入到SQL表中。实际上,我想插入值并返回最后插入的记录的“ID”。我使用以下代码。

public class MemberBasicData
{
    public int Id { get; set; }
    public string Mem_NA { get; set; }
    public string Mem_Occ { get; set; }     
}

插入时,ID会在数据库中自动递增。

public int CreateNewMember(string Mem_NA, string Mem_Occ )
{
    using (SqlConnection con=new SqlConnection(Config.ConnectionString))
    {
        using(SqlCommand cmd=new SqlCommand("INSERT INTO Mem_Basic(Mem_Na,Mem_Occ) VALUES(@na,@occ)",con))
        {
            cmd.Parameters.AddWithValue("@na", Mem_NA);
            cmd.Parameters.AddWithValue("@occ", Mem_Occ);
            con.Open();

            int modified = cmd.ExecuteNonQuery();

            if (con.State == System.Data.ConnectionState.Open) con.Close();
                return modified;
        }
    }
}

我知道ExecuteNonQuery表示影响行的数字。而不是我使用的

int modified = (int)cmd.ExecuteScalar();

但它不起作用。请帮我解决这个问题。有没有像cmd.ExecuteInsertAndGetID()这样的代码(不适用于我的代码)。

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18373461

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档