使用EFCore连接SQLite

简介

在使用EFCore连接SQLite之前我们先来了解一下SQLite

SQLite是一个轻量级、自包含、无服务器、零配置的事务性SQL数据库引擎,它支持SQL92标准的大多数查询语言并兼容ACID事务。具体如下:

  1. 轻量级:SQLite非常轻巧,它的库体积小,资源占用低,特别适合于嵌入式设备和移动应用,有时仅需几百KB的内存即可运行。
  2. 自包含:作为一个自给自足的数据库,SQLite不需要单独的服务器进程或操作系统进行管理。它通过直接访问磁盘文件进行数据存储。
  3. 无服务器:由于SQLite不需要运行服务器,因此简化了安装和管理过程,也降低了系统开销。
  4. 零配置:SQLite无需任何配置文件即可运行,使得它在简单性和易用性方面具有很大优势。
  5. 事务性:它支持事务(Transaction),即一系列操作要么完全成功,要么完全失败,这保证了数据的完整性。
  6. 兼容性:SQLite支持大部分SQL92标准,这意味着许多基于标准的SQL查询和命令都可以在SQLite上无缝运行。
  7. 跨平台:它可以在多种操作系统和平台上运行,包括Windows、Linux、Mac OS等。
  8. 多语言接口:SQLite提供了多种编程语言的API,如C、C++、Python、Java等,方便不同语言开发者使用。
  9. 开源:SQLite是开源软件,可以免费用于任何目的,包括商业用途。

安装Nuget包

新建一个.netCore的控制台项目

我们在项目的Nuget包管理器控制台中安装Microsoft.EntityFrameworkCore.Sqlite

复制代码
NuGet\Install-Package Microsoft.EntityFrameworkCore.Sqlite -Version 8.0.2

创建数据库

打开我们的数据库可视化管理工具Navicat,新建连接,选择SQLite

连接名随便取一个,类型选SQLite3,数据库文件选择放在我们刚刚创建的控制台项目下

创建一个Users表,待会测试用

数据库上下文

在项目中创建一个Users表的实体类和上下文类MyContext,如下图,刚刚创建的数据库文件与program类处于同一级

Users类

cs 复制代码
public class users
{
    public int Id { get; set; }
    public string Name { get; set; }
}

上下文 MyContext

数据库连接字符串:Data Source=data.db

定义一个名为 Users 的公共虚拟属性,它的类型是 DbSet<users>DbSet<TEntity> 是 EF Core 中的一个泛型类,表示数据库中的一个表。在这里,它表示 users 表。

virtual 关键字允许 EF Core 在内部使用延迟加载来加载相关数据。

cs 复制代码
public class MyContext : DbContext
{
    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        optionsBuilder.UseSqlite("Data Source=data.db");
    }

    public virtual DbSet<users> Users { get; set; } = null!;
}

Program

我们测试往数据库中添加一条数据,保存后再查询这条数据

cs 复制代码
class Program
{
    public static void Main(string[] args)
    {
        using (var db = new MyContext())
        {
            var user = new users() { Id = 1, Name = "张三" };
            db.Users.Add(user);
            db.SaveChanges();

            var users = db.Users.ToList();
        }
    }
}

可以看到,在下面代码中的Users中,已经查出刚刚添加的数据了

刷新一下我们的Navicate,发现还是空的

这是因为此时我们是调试状态,因此此时修改的数据库文件是Debug目录下的这个,并且每次调试这里的data.db都会被我们的程序目录下的data.db给替换掉

相关推荐
小陈phd2 分钟前
langGraph从入门到精通(六)——基于 LangGraph 实现结构化输出与智能 Router 路由代理
android·网络·数据库
安当加密4 分钟前
电力系统如何防“明文传输”?某电网公司用SM2+UKey构建“端到端加密”实战
服务器·数据库·安全·阿里云
BD_Marathon9 分钟前
动态SQL(六)foreach标签2
数据库·sql
小豪GO!9 分钟前
数据库-八股
数据库
IT大白9 分钟前
1、一条SQL是如何执行的
数据库·sql
变身缎带9 分钟前
Unity里基于Luban的buff系统
数据库·unity·游戏引擎
北京地铁1号线13 分钟前
2.2 向量数据库
数据库·elasticsearch·milvus·faiss·向量数据库·hnsw
悟能不能悟23 分钟前
查找oracle,存储过程包含某个单词的存储过程名称
数据库·oracle
马克学长1 小时前
SSM学生综合考评系统b8vlm(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·学生综合考评系统·高校学生管理、
独自破碎E1 小时前
MySQL中如何进行SQL调优?
数据库·sql·mysql