在 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”类型的异常

如何在 Entity Framework Core 2 中播种?