热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用EFCore在.NetCore控制台应用中操作SQLite数据库

本文介绍如何利用VisualStudio2019和Windows10环境,通过EntityFrameworkCore(EFCore)实现对SQLite数据库的读写操作。项目源代码可从百度网盘下载。

本文档基于Visual Studio 2019和Windows 10操作系统,指导开发者如何使用Entity Framework Core (EF Core) 在.NET Core控制台应用程序中实现SQLite数据库的读写功能。项目完整代码已上传至百度网盘,下载链接:点击下载,提取码:6a2l。



首先,创建一个新的.NET Core控制台应用程序,命名为ConsoleApp1。接着,通过NuGet包管理器安装必要的依赖包,包括:Microsoft.EntityFrameworkCore.SqliteMicrosoft.EntityFrameworkCore.DesignMicrosoft.EntityFrameworkCore.ToolsMicrosoft.Extensions.ConfigurationMicrosoft.Extensions.Configuration.Json。对于ASP.NET Core 2.1及更高版本,Microsoft.EntityFrameworkCore.Tools 已包含在 Microsoft.AspNetCore.App 元包中,而2.1之前的版本则需单独添加。



配置文件设置


在项目根目录下创建一个名为 appsettings.json 的配置文件,用于定义数据库连接字符串等信息。示例如下:


{
"ConnectionStrings": {
"db": "Data Source=./db/blogging.db"
}
}

确保将此文件的“复制到输出目录”属性设置为“如果较新则复制”,以便在编译时自动更新到输出目录。



定义数据模型


在项目中创建一个名为Models的新文件夹,并在其中定义两个实体类 Blog.csPost.cs,以及一个继承自 DbContext 的上下文类 BloggingContext.cs。这些类将映射到数据库中的表结构。


public class Blog {
public int BlogId { get; set; }
public string Url { get; set; }
public ICollection Posts { get; set; }
}

public class Post {
public int PostId { get; set; }
public string Title { get; set; }
public string Content { get; set; }
public int BlogId { get; set; }
public Blog Blog { get; set; }
}

public class BloggingContext : DbContext {
public DbSet Blogs { get; set; }
public DbSet Posts { get; set; }

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) {
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true);
var cOnfig= builder.Build();
optionsBuilder.UseSqlite(config.GetConnectionString("db"));
}
}


初始化数据库


为了创建数据库及其结构,需要执行迁移操作。首先,在项目根目录下创建一个名为db的文件夹,然后打开程序包管理控制台并运行以下命令:


Add-Migration InitialCreate
Update-Database

这将根据定义的数据模型生成数据库文件 blogging.db。同样地,将此文件的“复制到输出目录”属性设置为“如果较新则复制”。



测试数据库操作


最后,打开 Program.cs 文件,编写代码以测试数据库的增删查改功能。例如,添加一条新的博客记录,并从数据库中查询所有博客记录,显示在控制台窗口中。


static void Main(string[] args) {
using (var db = new BloggingContext()) {
db.Blogs.Add(new Blog { Url = "https://example.com" });
var count = db.SaveChanges();
Console.WriteLine($"{count} records saved to database");

Console.WriteLine("\nAll blogs in database:");
foreach (var blog in db.Blogs) {
Console.WriteLine(" - {0}", blog.Url);
}

Console.ReadKey();
}
}

运行程序,你将在控制台看到新添加的博客记录以及数据库中所有博客记录的URL。


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • andr ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 在前两篇文章中,我们探讨了 ControllerDescriptor 和 ActionDescriptor 这两个描述对象,分别对应控制器和操作方法。本文将基于 MVC3 源码进一步分析 ParameterDescriptor,即用于描述 Action 方法参数的对象,并详细介绍其工作原理。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • Java编程实践:深入理解方法重载
    本文介绍了Java中方法重载的概念及其应用。通过多个示例,详细讲解了如何在同一类中定义具有相同名称但不同参数列表的方法,以实现更灵活的功能调用。 ... [详细]
author-avatar
qaqa
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有