c# – 使用EF Code First Migration向表中的一个表添加新的必填字段
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 使用EF Code First Migration向表中的一个表添加新的必填字段,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1721字,纯文字阅读大概需要3分钟。
内容图文
![c# – 使用EF Code First Migration向表中的一个表添加新的必填字段](/upload/InfoBanner/zyjiaocheng/787/dc79f258db104fba8fa93ae850be7e85.jpg)
我正在使用EF Code First Migration.我已经有很多关于生产Db的数据,我想介绍一个不可空的字段.怎么可能?
目前它抛出一个错误:
The column cannot contain null values. [ Column name = Test,Table name = 'MyTable']
解决方法:
我通常使用的策略是首先将新列引入为可选,填充它,然后使其成为必需.实际上,您可以通过为每个步骤单独迁移或手动更改自动生成的迁移代码来进行单独的迁移步骤,以便在一次迁移中完成所有更改.我将描述如何使用单个迁移.
如果添加新的[Required]字段,则自动生成的迁移可能如下所示,如果dbo.MyTable中包含数据,则会失败:
public override void Up()
{
AddColumn("dbo.MyTable", "MyColumn", c => c.String(nullable: false));
}
public override void Down()
{
DropColumn("dbo.MyTable", "MyColumn");
}
您可以编辑迁移,以便最初将列添加为可选,预填充它,然后将其标记为必需.您可以使用Sql()执行预填充.根据您的数据,您可能希望根据其他列甚至另一个表计算新列的值,您可以通过编写适当的SQL来完成.
public override void Up()
{
AddColumn("dbo.MyTable", "MyColumn", c => c.String());
Sql("UPDATE dbo.MyTable SET MyColumn = COALESCE(SomeOtherColumn, 'My Fallback Value')");
AlterColumn("dbo.MyTable", "MyColumn", c => c.String(nullable: false));
}
public override void Down()
{
DropColumn("dbo.MyTable", "MyColumn");
}
如果您只想在所有行上设置相同的值,则可以跳过Sql()步骤,并在删除defaultValue之前根据需要使用defaultValue添加列.这允许您在迁移期间将所有行设置为相同的值,同时仍然需要在添加新行时手动指定值.据推测,这种方法不适用于旧版本的EF.我不确定需要哪个版本的EF,但它至少应该适用于现代版本(≥6.2):
public override void Up()
{
AddColumn("dbo.MyTable", "MyColumn", c => c.String(defaultValue: "Some Value", nullable: false));
AlterColumn("dbo.MyTable", "MyColumn", c => c.String(nullable: false));
}
public override void Down()
{
DropColumn("dbo.MyTable", "MyColumn");
}
内容总结
以上是互联网集市为您收集整理的c# – 使用EF Code First Migration向表中的一个表添加新的必填字段全部内容,希望文章能够帮你解决c# – 使用EF Code First Migration向表中的一个表添加新的必填字段所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。