1

我一直在尝试在数据库中插入一些数据,同时获取标识符。

标识符类型是 Guid。

我已经尝试了一些解决方案。

我正在搜索,但找不到任何与 C# 中的 Guid 一起使用的东西。

我尝试的最后一个是这样的:

        dbAccess db = new dbAccess();
        SqlConnection con = db.openConnection();
        Guid retVal = Guid.Empty;
        try
        {
            SqlCommand cmd = new SqlCommand(@"insert into Comment(IdDiscussion,UserId,Description,DateTime)
                                            values(@IdDiscussion,@UserId,@description,@dateTime);
                                            set @ret=SCOPE_IDENTITY();", con);
            cmd.Parameters.AddWithValue("@IdDiscussion", discussionId);
            cmd.Parameters.AddWithValue("@UserId", userId);
            cmd.Parameters.AddWithValue("@description", comment);
            cmd.Parameters.AddWithValue("@dateTime", dateTime);
            SqlParameter retParameter = new SqlParameter("@ret", SqlDbType.UniqueIdentifier);
            retParameter.Direction = ParameterDirection.Output;
            cmd.Parameters.Add(retParameter);
            cmd.ExecuteNonQuery();
            retVal = (Guid)retParameter.Value;
        }
        catch (Exception e)
        {
            //doesn't really matter
        }
        db.closeConnection();
        return retVal;

在这种情况下,我收到以下错误executeNonQuery(): "Operand type clash: numeric is incompatible with uniqueidentifier"

有什么可以帮助的建议吗?

4

2 回答 2

3

scope_identity() 仅返回最后一个(作用域)标识值 - 此值数据类型必须是数字。

所以不幸的是,我想到的唯一解决方法是这样的:

declare @op table
(
    ColGuid uniqueidentifier
)

insert into Comment(IdDiscussion,UserId,Description,DateTime)
output inserted.CommentId -- GUID column
into @op
values (@IdDiscussion,@UserId,@description,@dateTime)

select top 1 o.ColGuid
from @op o

然后在您的代码中:

var guid = (Guid)cmd.ExecuteScalar();

再提一提:此解决方案应适用于 SQL Server 2005 及更高版本

于 2013-06-19T09:56:08.547 回答
1

我尝试使用 SCOPE_IDENTITY() 来检索 Guid 值,但没有与我合作。您可以尝试声明一个 SQL 变量并使用命令 NEWID() 生成一个新的 guid,最后在此变量中执行 SELECT 命令,在命令对象上执行 ExecuteScalar 方法。

DECLARE @Id UNIQUEIDENTIFIER; SET @Id = NEWID();
INSERT INTO [tablename] ([Id], [Field1], [Field2]) VALUES (@Id, @Field1, @Field2);

您必须在命令中正常添加参数。

 cmd.Parameters.AddWithValue("@Field1", "Field 1 Value");
 cmd.Parameters.AddWithValue("@Field2", "Field 2 Value"));

因此,执行并检索该值。

var obj = cmd.ExecuteScalar();
Guid guid = (Guid)obj;
于 2015-07-13T02:36:55.707 回答