在 Entity Framework Core 中初始迁移后出现“没有这样的表”错误
Posted
技术标签:
【中文标题】在 Entity Framework Core 中初始迁移后出现“没有这样的表”错误【英文标题】:"No such table" error after initial migration in Entity Framework Core 【发布时间】:2021-04-26 08:56:21 【问题描述】:(Win7 x64,Visual Studio 2019,Entity Framework Core/SQLite/Tools v.5.0.2)
我关注这个
https://docs.microsoft.com/ru-ru/ef/core/get-started/overview/first-app?tabs=visual-studio
Entity Framework Core 教程。我复制/粘贴了所有代码以确保并使用 Nuget 控制台应用初始迁移。控制台根据日志报迁移成功:
PM> Update-Database
Build started...
Build succeeded.
Applying migration '20210121202929_InitialCreate'.
Done.
PM> Update-Database
Build started...
Build succeeded.
No migrations were applied. The database is already up to date.
Done.
PM>
虽然创建的数据库文件的文件图标表明可能有问题:
我尝试运行教程中的主要代码,但出现错误
没有这样的表:博客
代码:
namespace EFCTest6
class Program
static void Main(string[] args)
using (var db = new BloggingContext())
// Create
Console.WriteLine("Inserting a new blog");
// ERROR! SqliteException: SQLite Error 1: 'no such table: Blogs'.
db.Add(new Blog Url = "http://blogs.msdn.com/adonet" );
db.SaveChanges();
// Read
Console.WriteLine("Querying for a blog");
var blog = db.Blogs
.OrderBy(b => b.BlogId)
.First();
// Update
Console.WriteLine("Updating the blog and adding a post");
blog.Url = "https://devblogs.microsoft.com/dotnet";
blog.Posts.Add(
new Post
Title = "Hello World",
Content = "I wrote an app using EF Core!"
);
db.SaveChanges();
// Delete
Console.WriteLine("Delete the blog");
db.Remove(blog);
db.SaveChanges();
我还尝试将异常生成行从 db.Add(...)
更改为 db.Blogs.Add(...)
,但它会生成相同的异常。
【问题讨论】:
【参考方案1】:确保该表存在于数据库中。很多人,包括我自己,有时会在 Visual Studio 中将表添加到上下文中,然后应用迁移,但实际上忘记更新数据库。
在 Package-Manager 控制台 (Tools > Nuget Package Manager > Package manager Console
) 中输入以下内容并输入:
添加迁移“博客”
如果迁移尚不存在,这将添加迁移。然后输入
更新数据库
【讨论】:
以上是关于在 Entity Framework Core 中初始迁移后出现“没有这样的表”错误的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Entity Framework Core 中运行存储过程?
如何在 Entity Framework Core 中运行存储过程?
什么是自有实体?何时以及为什么在 Entity Framework Core 中使用 Owned Entity?
Entity Framework Core 中 TimeSpan 的总和
Entity Framework优化一:引发了“System.Data.Entity.Core.EntityCommandExecutionException”类型的异常