如何使用EF框架操作Sqlite

1.下载相关的NuGet

2.创建如下的项目结构

3.创建AppDbContext类

cs 复制代码
using Microsoft.EntityFrameworkCore;
using SaveSyetemConfiguration.Model;
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace SaveSyetemConfiguration.DBContext
{
    public class AppDbContext : Microsoft.EntityFrameworkCore.DbContext
    {
        // 数据库连接字符串(动态创建时可通过参数传入)
        private readonly string _connectionString;

        // 构造函数接收连接字符串(支持动态配置)
        public AppDbContext(string connectionString)
        {
            _connectionString = connectionString;
        }

        // 实体集(对应数据库表)
        public Microsoft.EntityFrameworkCore.DbSet<PerSon> PersonData { get; set; } = null;

        // 重写 OnConfiguring 配置数据库选项
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            if (!optionsBuilder.IsConfigured)
            {
                optionsBuilder.UseSqlite(_connectionString); // 使用 SQLite 提供程序
            }
        }
    }
}

4.创建对应的Model类

cs 复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace SaveSyetemConfiguration.Model
{
    public class PerSon
    {
        [Key]
        [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
        public long ID { get; set; }
        public string Name { get; set; }
        public int Age { get; set; }


    }
}

5.在程序类进行简单的操作

cs 复制代码
using SaveSyetemConfiguration.DBContext;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace SaveSyetemConfiguration
{
    internal class Program
    {
        static void Main(string[] args)
        {
            string DbPath = @"D:\NowText";
            string connectionString = "通道1";
            try
            {
                Directory.CreateDirectory(DbPath);
                connectionString = $"Data Source={DbPath}\\{connectionString}.db";
                AppDbContext Db = new AppDbContext(connectionString);
                Db.Database.EnsureCreated();

                Db.PersonData.Add(new Model.PerSon()
                {
                    Age = 1,
                    Name = "张三"
                });
                Db.PersonData.Add(new Model.PerSon()
                {
                    Age = 1,
                    Name = "李四"
                });
                var count = Db.SaveChanges();
            }
            catch (Exception)
            {
               
            }


        }


       


    }

}

结果如下:

相关推荐
海边夕阳20061 天前
数据源切换的陷阱:Spring Boot中@Transactional与@DS注解的冲突博弈与破局之道
java·数据库·spring boot·后端·架构
胜天半月子1 天前
性能测试 | 性能测试工具JMeter直连数据库和逻辑控制器的使用
数据库·测试工具·jmeter·性能测试
weixin_46681 天前
Redis主从复制
数据库·redis·缓存
小丁爱养花1 天前
Redis - hash & list (常用命令/内部编码/应用场景)
数据库·redis·哈希算法
半路_出家ren1 天前
图书销售系统数据库设计方案
数据库·mysql·子查询·ddl·dml·数据库设计·分组查询
自由会客室1 天前
Ubuntu24.04
数据库·postgresql
ayaya_mana1 天前
MySQL忘记Root密码,详细找回密码步骤
数据库·mysql·adb
顾三殇1 天前
【MySQL】win 10 / win11:mysql 5.7 下载、安装与配置
数据库·mysql
言之。1 天前
Django `select_related` 查询优化
数据库·django·sqlite
潜心编码1 天前
基于Django的医疗电子仪器系统
前端·数据库·1024程序员节