首页 > 解决方案 > 使用 SCOPE_IDENTITY 的 OUTPUT 参数 insetad 的问题

问题描述

我正在尝试使用OUTPUTparam 而不是SCOPE_IDENTITY在我的查询中。我浏览了一些资源,但不明白如何使用它。例如,我正在添加我现有的代码。

protected string Test(DataRow dataRow, out QueryParamList paramList)
    {
        paramList = new QueryParamList();

        StringBuilder sqlBuilder1 = new StringBuilder();
        StringBuilder sqlBuilder2 = new StringBuilder();

        for (int i = 0; i < dataRow.ItemArray.Length; i++)
        {
            if (!IsPrimaryKey(dataRow, i))
            {
                if (dataRow.ItemArray[i] != DBNull.Value)
                {
                    sqlBuilder1.Append(dataRow.Table.Columns[i].Caption + ",");
                    sqlBuilder2.Append("@" + dataRow.Table.Columns[i].Caption + ",");
                    DbType dbType = (DbType)Enum.Parse(typeof(DbType), dataRow.Table.Columns[i].DataType.Name);
                    paramList.Add(new QueryParamObj() { ParamName = dataRow.Table.Columns[i].Caption, ParamValue = dataRow.ItemArray[i], DBType = dbType });
                }
            }
        }
        if (sqlBuilder1.Length > 0) sqlBuilder1.Remove(sqlBuilder1.Length - 1, 1);
        if (sqlBuilder2.Length > 0) sqlBuilder2.Remove(sqlBuilder2.Length - 1, 1);

        string finalQuery = "Insert Into " + dataRow.Table.TableName + "(" + sqlBuilder1.ToString() + ")" + " values(" + sqlBuilder2.ToString() + ");select SCOPE_IDENTITY()";


        return finalQuery;
    }

在这里,finalQuery我想做出改变。

标签: sqlasp.nettsqlwebformsado.net

解决方案


基于将 OUTPUT INTO 与简单的 INSERT 语句一起使用,您可以遵循以下模式:

INSERT INTO TableName(..,..)
OUTPUT INSERTED...
VALUES (.., .., ..)

因此,在您的情况下,这应该有效(假设您的身份列是ID):

string finalQuery = "Insert Into " + dataRow.Table.TableName + "(" + sqlBuilder1.ToString() + ")" + " OUTPUT INSERTED.ID "+ " values(" + sqlBuilder2.ToString() + ");";

另请参阅IDENTITY、SCOPE_IDENTITY()、OUTPUT 和其他检索最后身份的方法


推荐阅读