过程中表值参数中的标识列,如何定义 DataTable

发布于 2024-09-08 10:45:12 字数 278 浏览 7 评论 0 原文

是否可以将类型为“table”的参数以及类型为“[int] IDENTITY(1,1)”的列传递给过程,并使用作为输入参数传递的 DataTable 对象来执行此存储过程?

我收到以下错误:“插入表变量不允许的标识列。 表值参数“@xxxxx”的数据不符合参数的表类型。”

我能找到的唯一相关评论是“如果您为表中的标识列提供值-值参数,您必须为会话发出 SET IDENTITY_INSERT 语句。”

似乎即使未在表参数中设置 PK,它也会在某个时刻自动设置。这种情况在哪里发生以及如何避免?

Is it possible to pass a parameter of type "table" with a column of type "[int] IDENTITY(1,1)" to a procedure and execute this stored procedure with a DataTable object passed as the input parameter?

I get the following error: "INSERT into an identity column not allowed on table variables.
The data for table-valued parameter \"@xxxxx\" doesn't conform to the table type of the parameter."

The only related comment I was able to find was "If you supply a value for an identity column in a table-valued parameter, you must issue the SET IDENTITY_INSERT statement for the session."

It seems that even though the PK was not set in the table parameter, it gets set automatically at some point. Where does that happen and how can it be avoided?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

在巴黎塔顶看东京樱花 2024-09-15 10:45:12

我遇到了同样的问题,我们想要类型的标识,但不想提供值。关键是为该列使用 SqlMetaData 构造函数,将 useServerDefault 设置为 true

根据 在 ado net 中使用带有标识列的用户定义表类型,作者:Tim Van Wassenhove

SQL

CREATE TYPE [Star].[example] AS TABLE(  
  [Ordinal] [int] IDENTITY(1,1) NOT NULL,  
  [Name] [nvarchar](200) NOT NULL,
)

C#

var sqlMetaData = new[] 
{  
  new SqlMetaData("Ordinal", SqlDbType.Int, true, false, SortOrder.Unspecified, -1),   
  new SqlMetaData("Name", SqlDbType.NVarChar, 200)
};

sqlRecords = new HashSet<SqlDataRecord>(usersToInclude.Select(user =>
{   
  var record = new SqlDataRecord(sqlMetaData);   
  record.SetString(1, user.Name);   
  return record; 
}));

new SqlMetaData("IdentityField", SqlDbType.Int, true, false, SortOrder.Unspecified, -1)

I had this same problem where we want an identity on the type, but don't want to provide a value. The key is to use a SqlMetaData constructor for that column that sets useServerDefault to true:

According to this article on using user defined table type with identify column in ado net by Tim Van Wassenhove

SQL:

CREATE TYPE [Star].[example] AS TABLE(  
  [Ordinal] [int] IDENTITY(1,1) NOT NULL,  
  [Name] [nvarchar](200) NOT NULL,
)

C#:

var sqlMetaData = new[] 
{  
  new SqlMetaData("Ordinal", SqlDbType.Int, true, false, SortOrder.Unspecified, -1),   
  new SqlMetaData("Name", SqlDbType.NVarChar, 200)
};

sqlRecords = new HashSet<SqlDataRecord>(usersToInclude.Select(user =>
{   
  var record = new SqlDataRecord(sqlMetaData);   
  record.SetString(1, user.Name);   
  return record; 
}));

new SqlMetaData("IdentityField", SqlDbType.Int, true, false, SortOrder.Unspecified, -1)
暮凉 2024-09-15 10:45:12

如果问题是“如何传递带有标记为 INT IDENTITY(1,1) 的列的 TVP?”你不知道。 TVP 不是一张桌子。您可能指定了 TVP 值,这意味着您不希望所提供的值具有标识。

该表通常是您想要声明 IDENTITY 的表。

如果问题是“如何避免在TVP中设置PK?”那么我就不得不要求更多的代码。

If the question is "how do I pass a TVP with a column marked INT IDENTITY(1,1)?" you don't. A TVP is not a table. You may be specifying the TVP values, which means that you don't want an identity on the value that you're supplying.

The table is usually the one that you want to have the IDENTITY declared on.

If the question is "How can I avoid setting the PK in the TVP?" then I would have to ask for more code.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文