news 2026/5/8 1:41:15

C#之安装和使用Sqlite数据库

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C#之安装和使用Sqlite数据库

C#之安装和使用Sqlite数据库

Sqlite数据库使用流程

1.安装 System.Data.Sqlite1.0.1172.安装 sqlite.codefirst3.App.Config配置连接字符串5.配置<provider invariantName="System.Data.SQLite"type="System.Data.SQLite.EF6.SQLiteProviderServices, System.Data.SQLite.EF6"/>3.创建ApplicationDbContext和User表实体

一 安装System.Data.Sqlite 1.0.117

二 安装 sqlite.codefirst

三 配置连接字符串

<connectionStrings><add name="SqliteDbContext"connectionString="data source=.\sqlite.db"providerName="System.Data.SQLite.EF6"/></connectionStrings>

<provider invariantName="System.Data.SQLite"type="System.Data.SQLite.EF6.SQLiteProviderServices, System.Data.SQLite.EF6"/>

后续联系



四 创建User表实体

EntityBase

/// <summary>/// 实体类型/// </summary>public class EntityBase:ObservableObject{privateintid;/// <summary>/// 自增主键/// </summary>[Key][DatabaseGenerated(DatabaseGeneratedOption.Identity)]//自动递增publicintId{get=>id;set=>SetProperty(ref id,value);}private DateTime insertDate=DateTime.Now;/// <summary>/// 插入时间/// </summary>public DateTime InsertDate{get=>insertDate;set=>SetProperty(ref insertDate,value);}}

User

[Table(nameof(User))]public class User:EntityBase{private string userName;public string UserName{get=>userName;set=>SetProperty(ref userName,value);}private string password;public string Password{get=>password;set=>SetProperty(ref password,value);}privateintrole;publicintRole{get=>role;set=>SetProperty(ref role,value);}}

User表的增删改查的接口设计

IRepository

where T:class 约束为类
public interface IRepository<T>where T:class{TGet(intid);intUpdate(T entity);intDelete(T entity);intInsert(T entity);List<T>GetAll();List<T>GetAll(string keyword);TSelect(string keyword);}

IUserRepository

public interface IUserRepository:IRepository<User>{}

增删改查实现

SqliteDbContext

public class SqliteDbContext:DbContext{//读取配置文件connectionStrings,创建数据库映射publicSqliteDbContext():base("SqliteDbContext"){}public DbSet<User>Users{get;set;}protected overridevoidOnModelCreating(DbModelBuilder modelBuilder){//base.OnModelCreating(modelBuilder);//注入我们设置的SqliteDbContext,判断数据库是否存在?不存在则创建。var sqliteConnect=new SqliteCreateDatabaseIfNotExists<SqliteDbContext>(modelBuilder);//执行Database.SetInitializer(sqliteConnect);}}

RepositoryBase

public abstract class RepositoryBase{protectedstaticSqliteDbContext db{get;}=new Lazy<SqliteDbContext>().Value;}

UserRepository

public class UserRepository:RepositoryBase,IUserRepository{publicintDelete(User entity){db.Entry(entity).State=System.Data.Entity.EntityState.Deleted;returndb.SaveChanges();}public UserGet(intid){returndb.Users.Find(id);}public List<User>GetAll(){returndb.Users.ToList();}public List<User>GetAll(string keyword){returndb.Users.ToList().Where(t=>t.UserName.Contains(keyword)).ToList();}publicintInsert(User entity){db.Users.Add(entity);returndb.SaveChanges();}public UserSelect(string keyword){returndb.Users.ToList().Find(t=>t.UserName==keyword);}publicintUpdate(User entity){db.Entry(entity).State=System.Data.Entity.EntityState.Modified;returndb.SaveChanges();}}

使用

publicMainWindow(){InitializeComponent();}UserRepository xx=newUserRepository();privatevoidButton_Click(object sender,RoutedEventArgs e){User newUser=newUser();newUser.UserName="admin";newUser.Password="12345678";newUser.InsertDate=DateTime.Now;intcount=xx.Insert(newUser);if(count>0){System.Windows.MessageBox.Show("插入成功");}var entity=xx.GetAll().FirstOrDefault();}

补充:

在WinForms开发中安装System.Data.SQLitesqlite.codefirstEntityFramework这三个库,各自承担不同的功能角色,以下是具体用途及分析:

1. System.Data.SQLite

核心作用:提供与SQLite数据库交互的底层ADO.NET接口。
功能细节

  • 原生SQLite支持:作为官方维护的库,直接封装SQLite的C语言接口,提供连接、命令执行、数据读取等基础操作。
  • 跨平台兼容性:支持Windows、Linux、macOS等平台,适合需要跨平台部署的WinForms应用。
  • 性能优化:针对SQLite特性优化,如内存管理、事务处理等,适合高频读写场景。
  • 独立使用:无需依赖其他ORM框架,可直接通过SQLiteConnectionSQLiteCommand等类操作数据库。

适用场景

  • 需要直接控制SQL语句执行的场景(如复杂查询、存储过程)。
  • 对性能要求较高,或需避免ORM框架开销的项目。
  • 跨平台WinForms应用开发。

示例代码

usingSystem.Data.SQLite;// 连接数据库using(varconnection=newSQLiteConnection("Data Source=mydb.sqlite")){connection.Open();// 执行SQL命令using(varcommand=newSQLiteCommand("SELECT * FROM Users",connection))using(varreader=command.ExecuteReader()){while(reader.Read()){Console.WriteLine(reader["Name"]);}}}

2. sqlite.codefirst

核心作用:通过Code First模式自动生成SQLite数据库表结构。
功能细节

  • Code First支持:允许开发者通过定义C#类(实体)自动创建或更新数据库表,无需手动编写SQL脚本。
  • 迁移管理:支持数据库迁移,可跟踪模型变化并自动应用变更到数据库。
  • 依赖EntityFramework:本质上是EntityFramework的扩展,需配合EF使用。

适用场景

  • 快速原型开发,需快速迭代数据库结构。
  • 团队熟悉EF的Code First模式,希望减少手动维护SQL脚本的工作量。
  • 需要与EntityFramework无缝集成的项目。

示例代码(需先安装EntityFramework):

// 定义实体类publicclassUser{publicintId{get;set;}publicstringName{get;set;}}// 配置DbContextpublicclassMyDbContext:DbContext{publicDbSet<User>Users{get;set;}protectedoverridevoidOnConfiguring(DbContextOptionsBuilderoptionsBuilder){optionsBuilder.UseSqlite("Data Source=mydb.sqlite");}}// 自动生成数据库using(varcontext=newMyDbContext()){context.Database.EnsureCreated();// 若数据库不存在则创建}

3. EntityFramework (EF)

核心作用:提供高级ORM(对象关系映射)功能,简化数据访问层开发。
功能细节

  • LINQ支持:通过LINQ查询语法直接操作数据库,无需编写SQL。
  • 变更跟踪:自动跟踪实体状态(新增、修改、删除),简化数据同步。
  • 延迟加载:支持按需加载关联数据,减少不必要的查询。
  • 多数据库支持:通过提供程序(如Microsoft.EntityFrameworkCore.Sqlite)支持多种数据库。

适用场景

  • 需要快速开发数据驱动型WinForms应用。
  • 团队熟悉EF,希望减少样板代码(如手动映射对象与表)。
  • 需要复杂查询或关联数据操作的场景。

示例代码(结合Microsoft.EntityFrameworkCore.Sqlite):

// 查询数据using(varcontext=newMyDbContext()){varusers=context.Users.Where(u=>u.Name.Contains("A")).ToList();foreach(varuserinusers){Console.WriteLine(user.Name);}}

三者的关系与选择建议

  • System.Data.SQLite:底层驱动,必选(若直接操作SQLite)。
  • EntityFramework:高层ORM,可选(若需简化数据访问)。
  • sqlite.codefirst:EF的扩展,可选(若需Code First模式)。

推荐组合

  • 基础场景System.Data.SQLite(直接操作数据库)。
  • 快速开发System.Data.SQLite+EntityFramework(ORM简化代码)。
  • 敏捷迭代System.Data.SQLite+EntityFramework+sqlite.codefirst(Code First自动管理表结构)。

注意事项

  • 若项目已使用EF Core,建议通过Microsoft.EntityFrameworkCore.Sqlite(而非System.Data.SQLite)作为提供程序,以避免冲突。
  • sqlite.codefirst非官方库,需评估其稳定性与维护性。

EF6

EF6(Entity Framework 6) 是 Microsoft 提供的 对象关系映射(ORM)框架,用于简化 .NET 应用程序与数据库的交互。它通过将数据库表映射为 C#/VB.NET 对象,使开发者能以面向对象的方式操作数据,而无需直接编写 SQL 语句。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/7 14:26:49

深度解析 - 软件包依赖安装机制与故障排除

一、问题现象重述 在Anolis OS 8.6系统&#xff08;基于RHEL 8.6&#xff09;中&#xff0c;已通过yum 4.7.0安装A-1.0.0和B-1.0.0软件包。当挂载OS-v2的ISO作为yum源后&#xff0c;执行yum install A B时出现以下典型现象&#xff1a; 系统提示需要安装多个新增依赖包部分依…

作者头像 李华
网站建设 2026/5/4 13:25:04

C++入门基础指南:引用全解析(从入门到精通)

&#x1f525;小叶-duck&#xff1a;个人主页 ❄️个人专栏&#xff1a;《Data-Structure-Learning》 《C入门到进阶&自我学习过程记录》 ✨未择之路&#xff0c;不须回头 已择之路&#xff0c;纵是荆棘遍野&#xff0c;亦作花海遨游 目录 前言 一、引用 1、引用的概念…

作者头像 李华
网站建设 2026/4/19 2:09:10

使用Docker快速启动LobeChat镜像的5种方式

使用Docker快速启动LobeChat镜像的5种方式 在AI应用日益普及的今天&#xff0c;越来越多开发者希望快速搭建一个功能完整、界面现代的聊天机器人前端。但直接从零开始构建Web界面、处理模型对接和用户交互逻辑&#xff0c;成本太高。这时候&#xff0c;像 LobeChat 这样的开源项…

作者头像 李华
网站建设 2026/5/5 7:47:17

PowerShell基础与命令发现

目录 文件与目录操作管道与数据处理系统信息查询进程、服务与网络状态文件哈希计算远程命令执行 1. 概述 PowerShell是Windows下的强大命令行Shell和脚本语言&#xff0c;用于系统管理和自动化。了解如何查找和使用命令是基础。 方法/工具 更改目录 * Set-Location …

作者头像 李华