最常用、最稳定的方式是使用 System.Data.SQLite(官方推荐的 ADO.NET 提供程序),支持 .NET Framework 和 .NET Core/.NET 5+,安装对应 NuGet 包后通过连接字符串指定数据库文件路径,配合 SQLiteCommand 参数化执行增删改查操作,并注意权限、引用包类型及多线程并发模式。

用 C# 连接 SQLite 数据库,最常用、最稳定的方式是使用 System.Data.SQLite(官方推荐的 ADO.NET 提供程序)。它支持 .NET Framework 和 .NET Core/.NET 5+(需用对应版本包),开箱即用,无需安装 SQLite 服务端。
安装 System.Data.SQLite 包
在 Visual Studio 的“包管理器控制台”中运行:
- 针对 .NET Framework 项目(如 WinForms、WPF):
Install-Package System.Data.SQLite - 针对 .NET Core / .NET 5+ 项目(推荐):
Install-Package System.Data.SQLite.Core(轻量纯托管版,跨平台兼容更好)
安装后,代码里加上 using System.Data.SQLite; 即可开始操作。
创建连接并打开数据库
SQLite 是文件型数据库,连接字符串只需指定数据库文件路径。如果文件不存在,首次打开时会自动创建。
- 基础连接字符串示例:
Data Source=app.db;Version=3; - C# 中打开连接:
string connectionString = "Data Source=app.db;Version=3;";
using (var conn = new SQLiteConnection(connectionString))
{
conn.Open(); // 文件自动创建,连接就绪
// 后续执行命令...
}执行查询和增删改操作
和标准 ADO.NET 一样,用 SQLiteCommand 配合参数化 SQL,避免 SQL 注入。
- 插入数据(带参数):
using (var cmd = new SQLiteCommand(conn))
{
cmd.CommandText = "INSERT INTO users(name, age) VALUES(@name, @age)";
cmd.Parameters.AddWithValue("@name", "张三");
cmd.Parameters.AddWithValue("@age", 28);
cmd.ExecuteNonQuery();
}- 读取数据:
cmd.CommandText = "SELECT * FROM users WHERE age > @minAge";
cmd.Parameters.AddWithValue("@minAge", 18);
using (var reader = cmd.ExecuteReader())
{
while (reader.Read())
{
string name = reader["name"].ToString();
int age = Convert.ToInt32(reader["age"]);
Console.WriteLine($"{name}, {age}");
}
}注意事项和常见问题
- 确保目标目录有写权限,否则
Open()会报错(尤其在某些 Windows 系统或发布后路径不对时) - 推荐使用
using语句自动释放连接和命令对象,防止资源泄漏 - 如果遇到“无法加载 DLL”错误,说明缺少本机 SQLite 库 —— 用
System.Data.SQLite.Core可避免此问题(纯托管实现) - 多线程访问 SQLite 时,默认是 Serialized 模式;如需并发写入,建议加锁或使用 WAL 模式(需在连接字符串加 Journal Mode=WAL;)
基本上就这些。System.Data.SQLite 封装规范、文档清晰,上手不难,但路径、权限、引用包类型这几个点容易忽略。










