Dapper在WinForms项目中怎么用 Dapper桌面应用开发教程

admin 百科 15
Dapper在WinForms中使用需三步:安装Dapper及对应数据库驱动;封装DataAccess类统一管理连接字符串、使用using确保连接释放、避免UI线程阻塞;调用时用async/await+Task.Run异步查询,通过this.Invoke更新控件,并注意增删改的事务与异常处理。

Dapper在WinForms项目中怎么用 Dapper桌面应用开发教程-第1张图片-佛山资讯网

Dapper 本身不区分 WinForms、WPF 或控制台,它只是一个轻量级的 .NET ORM,专做 SQL 映射。在 WinForms 中用 Dapper,核心就三件事:装包、建连接、写 SQL + 实体类。不复杂,但容易忽略线程和 UI 安全问题。

1. 引入 Dapper 和数据库驱动

打开 NuGet 包管理器,安装两个必要包:

  • Dapper(核心映射库)
  • Microsoft.Data.SqlClient(SQL Server)或 MySqlConnector(MySQL)、Npgsql(PostgreSQL)——选你实际用的数据库驱动

比如用 SQL Server,安装后代码里加引用:

// 在 Form 或数据访问类顶部
using Dapper;
using Microsoft.Data.SqlClient;

2. 封装一个安全的数据访问类

别把 SqlConnection 写满整个窗体。建议单独建个 DataAccess.cs,封装常用操作:

  • static string ConnectionString 统一管理连接字符串(可从 app.config 或 settings.settings 读)
  • 所有查询方法都用 using var conn = new SqlConnection(...) 确保及时释放
  • 避免在 UI 线程直接执行耗时查询(比如查几千条记录),否则界面卡死

示例:查用户列表

// DataAccess.cs
public static List GetUsers()
{
  using var conn = new SqlConnection(ConnectionString);
  return conn.Query("SELECT Id, Name, Email FROM Users").ToList();
}

3. 在 WinForms 中调用并更新控件

WinForms 默认是单线程 UI 模型,不能跨线程改控件(比如在 Task 里直接赋值 dataGridView1.DataSource = list 会报错)。安全做法:

标签: mysql app access ai win microsoft 应用开发 数据访问 点击事件 .net gate

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~