更改表中的主键(约束)时出错



更改表中的主键时出现问题。

错误:"无法在可为空的列上创建 IDENTITY 属性。

详情

  • "update"是派生自DataSourceObject和IClonable的类的枚举
  • "table"是一个派生自数据源对象的类

代码

foreach (var u in update)
{
   myList.Add(string.Format("alter table [{0}] alter column {1} {2} {3};", table.Name, u.Name, (u.IsPrimary || u.IsAutoIncrement) ? "not null" : "null"));
}

我还尝试像这样删除所有主键:

foreach (var u in update.Where(x => x.IsPrimary))
{    
   myList.Add(string.Format("alter table [{0}] drop constraint {1}", table.Name, u.Name));
}

但它说我尝试设置为 PrimaryKey 的当前项目不是约束。

我还提到,如果我以这种方式更改if语句(反之亦然):

(u.IsPrimary || u.IsAutoIncrement) ? "null" : "not null";

当我尝试更改回主键时,它可以工作。我的意思是,如果我先更改主键,那么就会出现异常,然后我更改 if 语句,然后更改 PrimaryKey 它就可以完成业务。

更新:现在我肯定知道我必须找到一个我要删除的约束名称,在我的情况下,它将是默认的 - ID(可以使用 sys 模式完成,但我不知道如何使用它),然后我必须删除它,毕竟我必须生成一个具有新名称的新约束。

结果查询:

declare @CONSTRAINTNAME varchar(128);
declare @script nvarchar(max);
select top 1 @CONSTRAINTNAME = t1.CONSTRAINT_NAME
from INFORMATION_SCHEMA.TABLE_CONSTRAINTS t1
where CONSTRAINT_TYPE = 'PRIMARY KEY' and upper(t1.TABLE_NAME) = @tableName;
set @script = N'alter table [' + @tableName + N'] drop constraint [' + @CONSTRAINTNAME + N']';
exec sp_executesql @script
set @script = N'alter table [' + @tableName + N'] add constraint [' + @tableName + '_' + @columnName + N'] primary key (['+ @columnName +'])';
exec sp_executesql @script

相关内容

  • 没有找到相关文章

最新更新