C#怎么连接SQLite数据库 C# System.Data.SQLite使用方法

来源:这里教程网 时间:2026-02-21 17:33:06 作者:

用 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 封装规范、文档清晰,上手不难,但路径、权限、引用包类型这几个点容易忽略。

相关推荐