C# Dapper的简单使用
Dapper介绍
Dapper 是一个轻量级的对象关系映射(Object - Relational Mapping,ORM)工具,它在.NET 应用程序中用于简化数据库访问操作。它提供了高性能、简单易用的方式来执行 SQL 查询和命令,并且与ADO.NET紧密集成。Dapper 的主要优势在于其简洁性和高性能,它能够快速地将数据库查询结果映射到 C# 对象,并且在执行 SQL 命令时具有较低的开销。
简单来说,它使用起来很方便,但是需要我们有一定的sql基础,他不是重量级的对象关系映射,所以内部没有封装方法让我们直接调用。
我们这里介绍一下简单使用,如果需要项目化使用Dapper的话可以参考一下我的下一篇文章。
简单使用
安装 Dapper
首先,你需要通过 NuGet 包管理器安装 Dapper。在 Visual Studio 的“包管理器控制台”中运行以下命令:
Install-Package Dapper
或者,你可以通过 NuGet 包管理器 GUI 搜索“Dapper”并安装它。
配置数据库连接
Dapper 本身不处理数据库连接,你需要使用 ADO.NET 或其他数据库连接库(如 System.Data.SqlClient 对于 SQL Server)来建立连接。
csharp
using System.Data.SqlClient;
string connectionString = "your_connection_string_here";
using (var connection = new SqlConnection(connectionString))
{
// 数据库操作代码将在这里编写
}
是不是非常的简单,接下来介绍一下数据库操作。
执行查询
Dapper 提供了多种方法来执行 SQL 查询并映射结果到对象。以下是一些常见的用法:
查询单个对象
var sql = "SELECT * FROM Users WHERE Id = @Id";
var user = connection.QuerySingleOrDefault<User>(sql, new { Id = userId });
在这个例子中,QuerySingleOrDefault 方法会执行 SQL 查询,并期望返回一个且仅返回一个结果。如果查询返回多个结果或没有结果,它将返回 default(User)(对于引用类型通常是 null)。
查询多个对象
var sql = "SELECT * FROM Users";
var users = connection.Query<User>(sql).ToList();
这里,Query 方法会执行 SQL 查询,并返回一个包含所有结果的 IEnumerable。你可以使用 .ToList() 方法将其转换为列表。
使用参数化查询
Dapper 支持参数化查询,这有助于防止 SQL 注入攻击。你可以使用匿名对象或具名参数来传递查询参数。
var sql = "SELECT * FROM Users WHERE Age > @Age";
var users = connection.Query<User>(sql, new { Age = 25 }).ToList();
执行命令
除了查询之外,Dapper 还可以用于执行非查询命令(如 INSERT、UPDATE、DELETE)。这里可以写增删改的语句。
var sql = "INSERT INTO Users (Name, Age) VALUES (@Name, @Age)";
var affectedRows = connection.Execute(sql, new { Name = "John Doe", Age = 30 });
Execute 方法会执行 SQL 命令,并返回受影响的行数。
事务处理
Dapper 支持事务处理,你可以使用 SqlTransaction 对象来管理事务。
using (var connection = new SqlConnection(connectionString))
{
connection.Open();
using (var transaction = connection.BeginTransaction())
{
try
{
// 执行一些数据库操作
var affectedRows = connection.Execute(sql, parameters, transaction);
// 如果一切正常,提交事务
transaction.Commit();
}
catch
{
// 如果出现异常,回滚事务
transaction.Rollback();
throw;
}
}
}
映射结果到自定义类型
Dapper 可以自动将查询结果映射到自定义类型。你需要确保你的自定义类型的属性名称与数据库表的列名称相匹配(或者使用别名)。
public class User
{
public int Id { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
总结
Dapper 是一个简单而强大的 ORM 框架,它提供了对 SQL 查询和存储过程的直接映射,同时保持了代码的清晰和高效
小白路漫漫,让我们一起加油!!!
原文地址:https://blog.csdn.net/weixin_52473844/article/details/144305337
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!