c# – 实体框架核心,代码首次迁移与数据迁移
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 实体框架核心,代码首次迁移与数据迁移,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3302字,纯文字阅读大概需要5分钟。
内容图文
![c# – 实体框架核心,代码首次迁移与数据迁移](/upload/InfoBanner/zyjiaocheng/797/c5dd312a4fed4d799f8435ca4244a839.jpg)
我正在尝试使用EF Core代码首次迁移来对现有表进行反规范化.
我有现有的表LoginEvent,其数据如下所示:
╔═════════════════════════════════════════════════╗
║ LoginEvent ║
╠════╦══════════╦═══════════╦════════════╦════════╣
║ Id ║ VenueRef ║ VenueName ║ OccurredAt ║ UserId ║
╠════╬══════════╬═══════════╬════════════╬════════╣
║ 1 ║ ven01 ║ Venue 1 ║ 2018-01-29 ║ 5 ║
╠════╬══════════╬═══════════╬════════════╬════════╣
║ 2 ║ ven02 ║ Venue 2 ║ 2018-01-30 ║ 7 ║
╠════╬══════════╬═══════════╬════════════╬════════╣
║ 3 ║ ven01 ║ Venue 1 ║ 2018-02-01 ║ 9 ║
╚════╩══════════╩═══════════╩════════════╩════════╝
public class LoginEvent
{
[Key]
public int Id { get; set; }
public string VenueRef { get; set; }
public string VenueName { get; set; }
public DateTime OccurredAt { get; set; }
public User User { get; set; }
}
我想将其规范化为两个表:LoginEvent和Venue,如下所示:
╔═════════════════════════════════════╗
║ LoginEvent ║
╠════╦══════════╦════════════╦════════╣
║ Id ║ VenueRef ║ OccurredAt ║ UserId ║
╠════╬══════════╬════════════╬════════╣
║ 1 ║ ven01 ║ 2018-01-29 ║ 5 ║
╠════╬══════════╬════════════╬════════╣
║ 2 ║ ven02 ║ 2018-01-30 ║ 7 ║
╠════╬══════════╬════════════╬════════╣
║ 3 ║ ven01 ║ 2018-02-01 ║ 9 ║
╚════╩══════════╩════════════╩════════╝
╔══════════════════════╗
║ Venue ║
╠══════════╦═══════════╣
║ VenueRef ║ VenueName ║
╠══════════╬═══════════╣
║ ven01 ║ Venue 1 ║
╠══════════╬═══════════╣
║ ven02 ║ Venue 2 ║
╚══════════╩═══════════╝
现在,我通过添加一个新的Venue域对象并让LoginEvent引用它来完成此操作,如下所示:
public class LoginEvent
{
[Key]
public int Id { get; set; }
public string VenueRef { get; set; }
public DateTime OccurredAt { get; set; }
public Venue Venue { get; set; }
public User User { get; set; }
}
public class Venue
{
[Key]
public string VenueRef { get; set; }
public string VenueName { get; set; }
}
然后我创建了一个迁移,(正确地):
>创建新的Venue表
>删除VenueName列
>设置两者之间的外键约束
但是,我需要做的是在步骤1和2之间运行数据迁移,以便在删除列之前和设置约束之前将现有场所放在新表中(否则,我将丢失数据和约束失败,因为我没有相关的场地).
我想像我的数据迁移一样运行这样的东西:
INSERT INTO Venue SELECT DISTINCT VenueRef, VenueName FROM LoginEvent
我该怎么做?
解决方法:
您可以使用migrationBuilder.Sql(theSqlString)执行任何SQL.
在你的情况下
migrationBuilder.Sql("INSERT INTO Venue SELECT DISTINCT VenueRef, VenueName FROM LoginEvent");
在创建新表Venue之后和删除旧列VenueName之前,在迁移中运行此命令.
另见Custom Migrations Operations.
内容总结
以上是互联网集市为您收集整理的c# – 实体框架核心,代码首次迁移与数据迁移全部内容,希望文章能够帮你解决c# – 实体框架核心,代码首次迁移与数据迁移所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。