『SQLite』C#/.NET EF+SQLite.CodeFirst——真正实现CodeFirst

2023-11-27 13:50

本文主要是介绍『SQLite』C#/.NET EF+SQLite.CodeFirst——真正实现CodeFirst,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

请添加图片描述

请添加图片描述
📣读完这篇文章里你能收获到

  • 本文详细介绍了SQLite实现CodeFirst的方式
  • 通过代码配合图文的形式进行讲解
  • 这篇文章强烈建议收藏!!!免得下次找不到

请添加图片描述

文章目录

  • 一、提前准备
    • 1 下载Sqlite Expert
    • 2 安装VS扩展工具
  • 二、项目接入
    • 1 先在NuGet中添加相关依赖项
    • 2 定义实体类
    • 3 添加Context类
    • 4 获取数据库连接字符串
    • 5 修改配置文件APP.config
  • 三、验证测试
    • 1 界面窗口布局
    • 2 按钮事件
    • 3 效果

请添加图片描述

本文所介绍的是真正的EF+CodeFirst,不需要提前建表,由代码自动生成!

一、提前准备

1 下载Sqlite Expert

下载Sqlite Expert

下载免费版个人版就够用了

在这里插入图片描述

  • 下载后新建数据库,然后保存到你指定的目录即可(保存为.db文件)

2 安装VS扩展工具

  • 然后在VS中->工具->扩展和更新->联机
    在这里插入图片描述
  • 搜索SQLite/SQL Server Compact ToolBox ,下载完后重启VS
    在这里插入图片描述
  • 在同一个地方再搜索dotConnect ADO.NET Data Provider for SQLite,记得不是安装Standard的,点下载后会出现个弹出框下载,下载完后安装时要先关闭VS
    在这里插入图片描述

请添加图片描述

二、项目接入

1 先在NuGet中添加相关依赖项

  • SQLite和SQLite.CodeFirst
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2 定义实体类

public class Student
{public int ID { get; set; }public string Name { get; set; }public int Age { get; set; }public string Gender { get; set; }
}

3 添加Context类

  • 继承自DbContext以及Model配置类
public class StudentContext : DbContext
{//定义属性,便于外部访问数据表public DbSet<Student> Students { get { return Set<Student>(); } }public StudentContext() : base("dbConn"){}protected override void OnModelCreating(DbModelBuilder modelBuilder){ModelConfiguration.Configure(modelBuilder);var init = new SqliteDropCreateDatabaseWhenModelChanges<StudentContext>(modelBuilder);//var init = new SqliteCreateDatabaseIfNotExists<MyBookDB>(modelBuilder);Database.SetInitializer(init);}
}public class ModelConfiguration
{public static void Configure(DbModelBuilder modelBuilder){ConfigureBookEntity(modelBuilder);}private static void ConfigureBookEntity(DbModelBuilder modelBuilder){modelBuilder.Entity<Student>();}
}

4 获取数据库连接字符串

  • 工具->连接到数据库->更改->选择SQLite Database->Browse数据库文件->测试成功后复制Connection String
    在这里插入图片描述
    在这里插入图片描述

5 修改配置文件APP.config

  • 在</system.data>结点后面添加连接字符串
  <connectionStrings><add name="SQLiteConnect" connectionString="Data Source=F:\xxx\SQLLiteTest.db" providerName="System.Data.SQLite.EF6"/></connectionStrings>
  • 添加Provider结点(主要原因是SQLite的invarianName不是在自动生成的.EF6里面)
<provider invariantName="System.Data.SQLite" type="System.Data.SQLite.EF6.SQLiteProviderServices, System.Data.SQLite.EF6" />

在这里插入图片描述

请添加图片描述

三、验证测试

1 界面窗口布局

在这里插入图片描述

2 按钮事件

private void btnAdd_Click(object sender, EventArgs e)
{List<Student> books = new List<Student>(){new Student() {ID=1, Name = "小明", Age = 11, Gender = "男" },new Student() {ID=2, Name = "老王",  Age = 12, Gender = "男" },new Student() {ID=3, Name = "小郭", Age = 10, Gender = "女" },new Student() {ID=4, Name = "小李",  Age = 11, Gender = "男" },new Student() {ID=5, Name = "小玉",  Age = 9, Gender = "女" },};using (var db = new StudentContext()){db.Students.AddRange(books);int count = db.SaveChanges();this.Text = $"{DateTime.Now}, 插入{count}条记录";}
}
private void btnModify_Click(object sender, EventArgs e)
{using (var db = new StudentContext()){var students = db.Students.FirstOrDefault(x => x.Name == "小李");if (students != null){students.Age += 1;int count = db.SaveChanges();this.Text = $"{DateTime.Now}, 修改{count}条记录";}}
}private void btnDel_Click(object sender, EventArgs e)
{using (var db = new StudentContext()){var students = db.Students.FirstOrDefault(x => x.Name == "小玉");if (students != null){var result = db.Students.Remove(students);int count = db.SaveChanges();this.Text = $"{DateTime.Now}, 删除{count}条记录";}}
}private void btnQuery_Click(object sender, EventArgs e)
{using (var db = new StudentContext()){var students = db.Students.Where(x => x.Name == "老王").OrderByDescending(x => x.Age).ToList();this.Text = $"{DateTime.Now}, 查到{students.Count}条记录";this.dataGridView1.DataSource = students;}
}private void btnRefresh_Click(object sender, EventArgs e)
{using (var db = new StudentContext()){var students = db.Students.ToList();this.dataGridView1.DataSource = students;}
}

3 效果

  • 根据代码生成表
    在这里插入图片描述
    在这里插入图片描述
    请添加图片描述

请添加图片描述

这篇关于『SQLite』C#/.NET EF+SQLite.CodeFirst——真正实现CodeFirst的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/427786

相关文章

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具