Dapper.SimpleCRUD:Dapper的CRUD助手

我们在项目开发中,面对一些高并发、大数据量等业务场景,往往对SQL语句的性能要求比较高,这个时候为了方便灵活控制,我们一般就会编写原生的SQL。

Dapper就是一个非常高性能的轻量级ORM框架,Dapper采用原生SQL语句的方式,对于CRUD这些简单操作我们一般都会自行封装,不然就会变成很繁琐。

今天给大家推荐一个Dapper的CRUD扩展库,就可以满足我们的需求,减少我们的工作量。

01 项目简介

Dapper.SimpleCRUD是一个开源项目,它基于Dapper开发的,为开发者提供了简单的CRUD操作帮助器。

Dapper本身是一个轻量级的ORM框架,它允许开发者使用SQL语句直接操作数据库,同时又能享受到ORM带来的便利,如参数化查询等。

而Dapper.SimpleCRUD则进一步简化了这一过程,让开发者能够更轻松地执行CRUD操作。

Dapper.SimpleCRUD的核心功能

CRUD操作:通过简单的API,开发者可以轻松地执行插入、读取、更新和删除操作,包括Get、GetList、Insert、Update、Delete等。通过扩展IDbConnection接口,可以直接使用,无需额外的配置。

模型属性支持:通过使用属性(如[Key]、[Table]、[Column]等),可以轻松地指定模型与数据库表之间的映射关系。同时提供[Editable(false)]、[ReadOnly(true)]、[IgnoreSelect]、[IgnoreInsert]、[IgnoreUpdate]等属性,用于控制模型属性在CRUD操作中的行为。

异步操作支持:对于需要处理大量数据或需要提高响应速度的应用,Dapper.SimpleCRUD提供了异步操作的支持。

02 使用方法

1、定义模型

csharp 复制代码
[Table("Users")]  
public class User  
{  
    [Key]  
    public int UserId { get; set; }  
    public string FirstName { get; set; }  
    public string LastName { get; set; }  
    public int Age { get; set; }  

    // 额外的、不在数据库中的属性  
    [Editable(false)]  
    public string FullName { get { return string.Format("{0} {1}", FirstName, LastName); } }  
}

2、执行CRUD操作

ini 复制代码
// 假设已经有一个打开的数据库连接 connection  

// 插入操作  
var newId = connection.Insert(new User { FirstName = "John", LastName = "Doe", Age = 30 });  

// 读取操作  
var user = connection.Get<User>(newId);  

// 更新操作  
user.Age = 31;  
connection.Update(user);  

// 删除操作  
connection.Delete<User>(newId);

03 项目地址

github.com/ericdc1/Dap...

更多开源项目: github.com/bianchengle...

- End -

推荐阅读

2个零基础入门框架教程!

Html2OpenXml:HTML转化为OpenXml的.Net库,轻松实现Html转为Word。

SharpLab:.Net反编译工具,方便实时查看反编译后的代码!

盘点4个.Net跨平台图形开源库!

Flurl:一个Star 3.9K的链式RESTful风格HTTP开源.Net库

相关推荐
我命由我123452 小时前
35.Java线程池(线程池概述、线程池的架构、线程池的种类与创建、线程池的底层原理、线程池的工作流程、线程池的拒绝策略、自定义线程池)
java·服务器·开发语言·jvm·后端·架构·java-ee
whoarethenext5 小时前
qt的基本使用
开发语言·c++·后端·qt
草捏子8 小时前
主从延迟导致数据读不到?手把手教你架构级解决方案
后端
橘猫云计算机设计9 小时前
基于Python电影数据的实时分析可视化系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·后端·python·信息可视化·小程序·毕业设计
Yolo@~9 小时前
SpringBoot无法访问静态资源文件CSS、Js问题
java·spring boot·后端
大鸡腿同学10 小时前
资源背后的成事密码
后端
Asthenia041210 小时前
使用 Spring Cloud Gateway 实现四种限流方案:固定窗口、滑动窗口、令牌桶与漏桶
后端
老李不敲代码11 小时前
榕壹云门店管理系统:基于Spring Boot+Mysql+UniApp的智慧解决方案
spring boot·后端·mysql·微信小程序·小程序·uni-app·软件需求
海风极客11 小时前
Go小技巧&易错点100例(二十五)
开发语言·后端·golang
喵手11 小时前
如何使用 Spring Boot 实现分页和排序?
数据库·spring boot·后端