经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C# » 查看文章
C#开源、简单易用的Dapper扩展类库 - Dommel
来源:cnblogs  作者:追逐时光者  时间:2024/7/23 9:07:27  对本文有异议

前言

今天大姚给大家分享一个C#开源(MIT License)、免费、简单易用的Dapper扩展类库,帮助.NET开发者使用Dapper的CRUD操作变得更简单:Dommel。

项目特性

  • Dommel 使用 IDbConnection 接口上的扩展方法为 CRUD 操作提供了便捷的 API。
  • Dommel 能够根据你的 POCO 实体自动生成相应的 SQL 查询语句。这大大减少了手动编写 SQL 代码的工作量,并提高了代码的可读性和可维护性。
  • Dommel 支持 LINQ 表达式,这些表达式会被翻译成 SQL 表达式并执行。这使得开发者能够使用更高级、更灵活的查询语法。
  • Dommel 使用 Dapper 作为底层库来执行查询和对象映射。

Dapper

Dapper是一个简单的.NET对象映射器,在速度方面具有"King of Micro ORM"的头衔,几乎与使用原始的ADO.NET数据读取器一样快。ORM是一个对象关系映射器,它负责数据库和编程语言之间的映射。Dapper通过扩展IDbConnection提供一些有用的扩展方法去查询您的数据库。

 

项目源代码

项目使用

以下是Dommel的简单的CRUD操作,更多实用且复杂操作可以前往项目源码地址查看(文末附带项目源码地址)。

安装Dommel包

定义Product实体类

  1. public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public int InStock { get; set; }
        public DateTime Created { get; set; }
    }

数据新增

  1. var product = new Product { Name = "Awesome bike", InStock = 4 };
    var id = await connection.InsertAsync(product);

数据删除

  1. var product = await connection.GetAsync<Product>(1);
    await connection.DeleteAsync(product);

数据修改

  1. var product = await connection.GetAsync<Product>(1);
    product.Name = "New name";
    await connection.UpdateAsync(product);

数据查询

  1. var product = await connection.GetAsync<Product>(1);
    var products1 = await connection.GetAllAsync<Product>();
    var products2 = await connection.SelectAsync<Product>(=> p.Name == "Awesome bike" && p.Created < new DateTime(2014, 12, 31) && p.InStock > 5);
    var products3 = await connection.SelectAsync<Product>(=> p.Name.Contains("bike"));
    var products4 = await connection.SelectAsync<Product>(=> p.Name.StartsWith("bike"));
    var products5 = await connection.SelectAsync<Product>(=> p.Name.EndsWith("bike"));

项目源码地址

更多项目实用功能和特性欢迎前往项目开源地址查看??,别忘了给项目一个Star支持??。

值得推荐的.NET ORM框架

优秀项目和框架精选

该项目已收录到C#/.NET/.NET Core优秀项目和框架精选中,关注优秀项目和框架精选能让你及时了解C#、.NET和.NET Core领域的最新动态和最佳实践,提高开发工作效率和质量。坑已挖,欢迎大家踊跃提交PR推荐或自荐(让优秀的项目和框架不被埋没??)。

原文链接:https://www.cnblogs.com/Can-daydayup/p/18317443

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号