热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

推荐:利用Dapper.SimpleCRUD扩展Dapper功能以简化CRUD操作

Dapper作为广受欢迎的ORM框架之一,虽然灵活性极高,但在处理基本的CRUD操作时仍需手动编写SQL语句,这无疑增加了开发工作量。为了解决这一问题,Dapper.SimpleCRUD扩展库应运而生。该扩展库通过提供简洁的方法,显著简化了数据访问层的开发流程,使开发者能够更加高效地进行读取、插入、更新和删除操作。此外,Dapper.SimpleCRUD还支持事务管理和批量操作,进一步提升了开发效率和代码可维护性。

背景

Dapper目前应该是大家比较喜欢的orm框架之一,但是它灵活的背后,还是有很多不尽人意的地方,谁想编写基本的读取/插入/更新/删除语句?下面推荐SimpleCRUD为Dapper提供了简单的CRUD帮助器。解放了大家,提高生产力。

功能特性

此扩展添加了以下8个助手:

  • Get(ID)-根据主键获取一条记录

  • GetList ()-获取记录列表,来自表的所有记录

  • GetList (where子句的匿名对象)-获取与where选项匹配的所有记录的列表

  • GetList (条件字符串,带参数的匿名对象)-获取与条件匹配的所有记录的列表

  • GetListPaged (int页码,int每页int,条件字符串,顺序字符串,带参数的匿名对象)-获取与条件匹配的所有记录的分页列表

  • Insert(entity)-插入一条记录并返回新的主键(假定为int主键)

  • Insert (entity)-插入一条记录并返回新的guid主键

  • 更新(实体)-更新记录

  • Delete (id)-基于主键删除记录

  • Delete(entity)-根据类型化的实体删除记录

  • DeleteList (where子句的匿名对象)-删除所有与where选项匹配的记录

  • DeleteList (条件的字符串,带参数的匿名对象)-删除与条件匹配的所有记录的列表

  • RecordCount (条件字符串,带参数的匿名对象)-获取与条件匹配的所有记录的计数

对于面向.NET 4.5或更高版本的项目,以下8个助手用于异步操作:

  • GetAsync(id)-根据主键获取一条记录

  • GetListAsync ()-获取记录列表来自表的所有记录

  • GetListAsync (where子句的匿名对象)-获取与where选项匹配的所有记录的列表

  • GetListAsync (条件字符串,带参数的匿名对象)-获取与条件匹配的所有记录的列表

  • GetListPagedAsync (int页面号,int itemsperpage,条件字符串,命令字符串,带有参数的匿名对象)-获取与条件匹配的所有记录的分页列表

  • InsertAsync(entity)-插入一条记录并返回新的主键(假定为int主键)

  • InsertAsync (entity)-插入一条记录并返回新的guid主键

  • UpdateAsync(entity)-更新记录

  • DeleteAsync (id)-基于主键删除记录

  • DeleteAsync(entity)-根据类型化的实体删除记录

  • DeleteListAsync (where子句的匿名对象)-删除所有与where选项匹配的记录

  • DeleteListAsync (条件字符串,带参数的匿名对象)-删除与条件匹配的所有记录的列表

  • RecordCountAsync (条件字符串,带参数的匿名对象)-获取与条件匹配的所有记录的计数

如果您需要更复杂的东西,请使用Dapper的Query或Execute方法!

数据库支持

有一个更改数据库方言的选项。默认值为Microsoft SQL Server,但可以更改为PostgreSQL或MySQL。我们在.Net Core版本中删除了对SQLite的支持。

开源地址

https://github.com/ericdc1/Dapper.SimpleCRUD



推荐阅读
  • SQL执行计划解析(2) 基本查询的图形执行计划
    SQL执行计划解析(2)-基本查询的图形执行计划(上)某种程度上,学习阅读图形执行计划和学习一门新语言很类似。 ... [详细]
  • 文章目录17、less17-UpdateQuery-Errorbased-String18、less18-HeaderInjection-ErrorBased-string19、l ... [详细]
  • 解决MySQL错误2002:无法建立数据库连接
    本文详细描述了在Digital Ocean服务器上托管的多个WordPress站点突然出现数据库连接错误的情况,并提供了有效的解决方案。 ... [详细]
  • 本文详细探讨了如何在 SparkSQL 中创建 DataFrame,涵盖了从基本概念到具体实践的各种方法。作为持续学习的一部分,本文将持续更新以提供最新信息。 ... [详细]
  • 本文档详细介绍了在 CentOS Linux 7.9 系统环境下,如何从源代码编译安装 libwebsockets 库及其示例程序,并提供了编译过程中可能遇到的问题及解决方案。 ... [详细]
  • 优化 DropDownList 与 TextBox 的交互体验
    本文介绍了一种解决方案,通过在 DropDownList 前添加一个 TextBox 来提升用户体验。当选项过多时,用户可以通过在 TextBox 中输入关键词来快速定位并选择相应的选项。 ... [详细]
  • Flask框架下MySQL数据库的集成与应用
    本文详细探讨了如何在Flask框架中集成和使用MySQL数据库,通过具体的实例和代码演示,帮助开发者更好地理解和掌握Flask与MySQL的结合使用。 ... [详细]
  • 本教程将指导您完成 Spring Boot 应用程序中 MySQL 数据库的配置,并通过 JdbcTemplate 进行基本的数据操作测试。在此之前,我们已经成功打包并测试了 jar 和 war 包,同时实现了 JSP 页面的访问,但页面数据是静态配置的。现在,让我们一起进入数据库配置的世界。 ... [详细]
  • 本文详细介绍了Django框架内置的对象关系映射(ORM)机制,包括其工作原理、如何连接MySQL数据库以及ORM的主要优势和局限性。同时,提供了配置和使用Django ORM的具体步骤。 ... [详细]
  • 本文详细介绍了一种利用局域网环境将本地SQL Server数据库备份至另一台计算机的方法。主要步骤包括在目标机器上设置共享文件夹、配置SQL Server以支持备份任务,并通过定时任务实现自动化备份。 ... [详细]
  • 深入理解HTTP及TCP基础知识
    本文详细解析了TCP的三次握手与四次挥手过程,探讨了HTTP与HTTPS的区别及其特性,并深入讲解了HTTP缓存机制以及GET与POST请求的主要差异。 ... [详细]
  • JSP与MySQL集成:实现数据添加与查询功能
    本文介绍了如何使用JSP和MySQL数据库来实现基本的数据添加和查询功能,包括数据库的准备、JSP页面的编写以及数据操作的具体步骤。 ... [详细]
  • 现代软件工程开发体验:结对编程
    距现代软件工程开课已经3周,按照课程安排,在最近的9天中,我们进行了极限编程模式的体验:pairwork(结对编程,具体见链接),对象是在academicsearchmap上添加一些新特性。经过选 ... [详细]
  • 深入理解SSM框架下的动态SQL
    本文详细探讨了在SSM框架中如何利用MyBatis实现动态SQL,通过具体示例说明了if、where、choose、set、trim、foreach、sql、include和bind等元素的使用方法及其作用。 ... [详细]
  • 深入理解ThinkPHP5.1自定义标签的应用与实现
    本文详细探讨了ThinkPHP5.1框架中自定义标签的创建与使用方法,包括标签库的建立、模板配置以及在实际项目中的应用技巧。 ... [详细]
author-avatar
波猫小丝992
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有