使用System.Data.SQLite库可实现C#中对SQLite数据库的连接与操作。1. 通过NuGet安装System.Data.SQLite包;2. 引入using System.Data.SQLite命名空间;3. 使用SQLiteConnection类配合连接字符串(如"Data Source=example.db;Version=3;")连接或创建数据库;4. 利用SQLiteCommand执行建表、插入等SQL语句,推荐使用参数化查询防止注入;5. 通过SQLiteCommand与SQLiteDataReader读取数据;6. 多写入操作应使用SQLiteTransaction确保一致性;7. 注意平台兼容性及资源释放。该库适用于.NET Framework与.NET Core,功能完整,适合中小型项目。

在C#中连接和操作SQLite数据库,最常用的方式是使用 System.Data.SQLite 库。它是一个开源的 ADO.NET 数据提供程序,专为 SQLite 设计,支持 .NET Framework 和 .NET Core/.NET 5+。以下是详细的使用方法。
要使用 System.Data.sqlite,你需要先安装对应的 NuGet 包:
打开 Visual Studio → 右键项目 → 管理 NuGet 程序包 → 搜索并安装 System.Data.SQLite或者通过 NuGet 包管理器控制台运行命令:
Install-Package System.Data.SQLite
安装后会自动添加对 System.Data.SQLite.dll 的引用。
在代码文件顶部引入必要的命名空间:
using System.Data.SQLite;
使用 SQLiteConnection 类来建立数据库连接。如果数据库文件不存在,可以自动创建。
示例:连接到本地数据库文件(若不存在则创建)
string connectionString = "Data Source=example.db;Version=3;New=True;Compress=True;";
using (var connection = new SQLiteConnection(connectionString))
{
connection.Open();
Console.WriteLine("数据库连接成功!");
}常见连接字符串参数说明:
使用 SQLiteCommand 执行 SQL 语句。
using (var connection = new SQLiteConnection("Data Source=test.db;Version=3;"))
{
connection.Open();
// 创建表
string createTableSql = "CREATE TABLE IF NOT EXISTS Users (Id INTEGER PRIMARY KEY, Name TEXT, Age INTEGER)";
using (var cmd = new SQLiteCommand(createTableSql, connection))
{
cmd.ExecuteNonQuery();
}
// 插入数据
string insertSql = "INSERT INTO Users (Name, Age) VALUES (@name, @age)";
using (var cmd = new SQLiteCommand(insertSql, connection))
{
cmd.Parameters.AddWithValue("@name", "张三");
cmd.Parameters.AddWithValue("@age", 25);
cmd.ExecuteNonQuery();
}
}使用 SQLiteCommand 配合 SQLiteDataReader 读取查询结果。
string selectSql = "SELECT Id, Name, Age FROM Users";
using (var cmd = new SQLiteCommand(selectSql, connection))
using (var reader = cmd.ExecuteReader())
{
while (reader.Read())
{
int id = reader.GetInt32("Id");
string name = reader.GetString("Name");
int age = reader.GetInt32("Age");
Console.WriteLine($"ID: {id}, 姓名: {name}, 年龄: {age}");
}
}对于多条写入操作,建议使用事务确保数据一致性。
using (var transaction = connection.BeginTransaction())
{
try
{
var cmd = connection.CreateCommand();
cmd.Transaction = transaction;
cmd.CommandText = "INSERT INTO Users (Name, Age) VALUES ('李四', 30)";
cmd.ExecuteNonQuery();
cmd.CommandText = "INSERT INTO Users (Name, Age) VALUES ('王五', 28)";
cmd.ExecuteNonQuery();
transaction.Commit();
}
catch
{
transaction.Rollback();
throw;
}
}以上就是C#如何连接SQLite数据库 C# System.Data.SQLite的使用方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号