0

我有一个插入查询,如下所示。但是,scopeIdentity不返回 42,而是返回 1042。

这是 SQL Server 表:

在此处输入图像描述

我的代码:

int masterId = 0;

using (SqlConnection cmd = new SqlConnection(connString))
{
    using (SqlCommand conn = cmd.CreateCommand())
    {
        conn.CommandText = "INSERT INTO[MasterReportData]([ReportName],[CaseList],[EmployeeId],[datetime]) VALUES(@reportName, @caseList, @employeeId, @datetime) SET @ID = SCOPE_IDENTITY()";

        conn.Parameters.Add("@reportName", SqlDbType.VarChar).Value = reportName;
        conn.Parameters.Add("@caseList", SqlDbType.VarChar).Value = caseList;
        conn.Parameters.Add("@employeeId", SqlDbType.Char).Value = employeeId;
        conn.Parameters.Add("@datetime", SqlDbType.DateTime).Value = datetime;
        conn.Parameters.Add("@ID", SqlDbType.Int).Direction = ParameterDirection.Output;

        cmd.Open();
        conn.ExecuteNonQuery();

        masterId = Convert.ToInt32(conn.Parameters["@ID"].Value);
        cmd.Close();
    }
}
4

1 回答 1

0

看看https://docs.microsoft.com/en-us/sql/t-sql/functions/scope-identity-transact-sql

描述说: 返回插入到同一范围内的标识列中的最后一个标识值。范围是一个模块:存储过程、触发器、函数或批处理。因此,如果两个语句在同一个存储过程、函数或批处理中,它们就在同一个范围内。

换句话说:它返回最后一个 id 而不是下一个要使用的。因此,您不能像那样使用 INSERT 命令。你可以做的是:

将您的 ID 配置为自动增量 ID。然后运行 ​​INSERT 命令并在之后运行 SELECT SCOPE_IDENTITY() 以找出使用了哪个 ID。

于 2017-09-11T10:03:02.923 回答