您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

.NET Core下有热门的ORM框架使用方法

时间:2023-11-16 13:10:06  来源:  作者:

.NET Core下有很多热门的ORM框架,以下是其中六个常用的框架,包括EF Core、DApper、NHibernate、Fluent NHibernate、LLBLGen Pro和PetaPoco。接下来,我将为您详细介绍每个框架的优缺点,并提供示例代码演示如何使用。

  1. Entity Framework Core (EF Core)
  • 优点: EF Core是.NET Core官方推荐的ORM框架,具有广泛的社区支持和文档资源。提供了强大的对象关系映射和LINQ查询功能,可以简化开发过程。支持多种数据库提供程序,包括SQL Server、MySQL、SQLite等。缺点: EF Core的性能相对较低,因为它需要进行较多的映射和转换操作。在一些高级查询和复杂映射方面,EF Core的功能可能不如其他框架强大。

示例代码:

// 定义模型类
public class Product
{
public int Id { get; set; }
public string Name { get; set; }
public decimal Price { get; set; }
}
// 创建DbContext
public class MyDbContext : DbContext
{
public DbSet<Product> Products { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlServer("connectionString");
}
}
// 查询数据
using (var dbContext = new MyDbContext())
{
var products = dbContext.Products.Where(p => p.Price > 10).ToList();
}
// 插入数据
using (var dbContext = new MyDbContext())
{
var newProduct = new Product { Name = "New Product", Price = 20 };
dbContext.Products.Add(newProduct);
dbContext.SaveChanges();
}
  1. Dapper
  • 优点: Dapper是一个轻量级的ORM框架,性能出色,适用于对性能要求较高的项目。提供了简洁的API,易于学习和使用。支持多种数据库,包括SQL Server、MySQL、Oracle等。缺点: Dapper相对于EF Core来说,功能较为简单,不提供ORM中的一些高级特性,如自动迁移、关联查询等。

示例代码:

// 查询数据
using (var connection = new SqlConnection("connectionString"))
{
var products = connection.Query<Product>("SELECT * FROM Products WHERE Price > @Price", new { Price = 10 }).ToList();
}
// 插入数据
using (var connection = new SqlConnection("connectionString"))
{
var newProduct = new Product { Name = "New Product", Price = 20 };
connection.Execute("INSERT INTO Products (Name, Price) VALUES (@Name, @Price)", newProduct);
}
  1. NHibernate
  • 优点: NHibernate是一个成熟稳定的ORM框架,具有广泛的社区支持和文档资源。提供了丰富的特性和高度的可定制性,适用于复杂的数据映射和查询场景。支持多种数据库,包括SQL Server、MySQL、Oracle等。缺点: 学习曲线较陡峭,配置和使用相对复杂。性能相对较低,因为需要进行较多的映射和转换操作。

示例代码:

// 定义映射文件
public class ProductMap : ClassMapping<Product>
{
public ProductMap()
{
Id(x => x.Id, map => map.Generator(Generators.Identity));
Property(x => x.Name);
Property(x => x.Price);
Table("Products");
}
}
// 创建SessionFactory
var configuration = new Configuration();
configuration.Configure(); // 加载配置文件
configuration.AddMapping(typeof(ProductMap)); // 添加映射文件
var sessionFactory = configuration.BuildSessionFactory();
// 查询数据
using (var session = sessionFactory.OpenSession())
{
using (var transaction = session.BeginTransaction())
{
var products = session.Query<Product>().Where(p => p.Price > 10).ToList();
transaction.Commit();
}
}
// 插入数据
using (var session = sessionFactory.OpenSession())
{
using (var transaction = session.BeginTransaction())
{
var newProduct = new Product { Name = "New Product", Price = 20 };
session.Save(newProduct);
transaction.Commit();
}
}
  1. Fluent NHibernate
  • 优点: Fluent NHibernate是NHibernate的一个扩展,提供了更加流畅和可读性更高的方式来进行映射配置。简化了NHibernate的配置过程,使代码更加易于维护。支持多种数据库,包括SQL Server、MySQL、Oracle等。缺点: 学习曲线较陡峭,对NHibernate的理解要求较高。性能相对较低,因为需要进行较多的映射和转换操作。

示例代码:

// 定义映射类
public class ProductMap : ClassMap<Product>
{
public ProductMap()
{
Id(x => x.Id);
Map(x => x.Name);
Map(x => x.Price);
Table("Products");
}
}
// 创建SessionFactory
var sessionFactory = Fluently.Configure()
.Database(MsSqlConfiguration.MsSql2012.ConnectionString("connectionString"))
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<ProductMap>())
.BuildSessionFactory();
// 查询数据
using (var session = sessionFactory.OpenSession())
{
using (var transaction = session.BeginTransaction())
{
var products = session.Query<Product>().Where(p => p.Price > 10).ToList();
transaction.Commit();
}
}
// 插入数据
using (var session = sessionFactory.OpenSession())
{
using (var transaction = session.BeginTransaction())
{
var newProduct = new Product { Name = "New Product", Price = 20 };
session.Save(newProduct);
transaction.Commit();
}
}
  1. LLBLGen Pro
  • 优点: LLBLGen Pro是一个商业级的ORM框架,提供了强大的对象关系映射和查询功能。支持多种数据库,包括SQL Server、MySQL、Oracle等。具有高度可定制性,适用于复杂的数据映射和查询场景。缺点: 是一个商业框架,需要购买许可证才能使用。学习曲线较陡峭,配置和使用相对复杂。

示例代码:

// 定义模型类
[Serializable]
[DataEntity(IsGenerated = true)]
public partial class Product : EntityBase
{
[DataField(IsPrimaryKey = true, IsIdentity = true)]
public int Id { get; set; }
[DataField]
public string Name { get; set; }
[DataField]
public decimal Price { get; set; }
}
// 查询数据
using (var adapter = new DataAccessAdapter())
{
var products = adapter.FetchQuery<Product>(new RelationPredicateBucket(ProductFields.Price > 10));
}
// 插入数据
using (var adapter = new DataAccessAdapter())
{
var newProduct = new Product { Name = "New Product", Price = 20 };
adapter.SaveEntity(newProduct);
}
  1. PetaPoco
  • 优点: PetaPoco是一个轻量级的ORM框架,具有简单易用的特点。性能较高,具有快速的数据访问和查询能力。支持多种数据库,包括SQL Server、MySQL、SQLite等。缺点: 不支持复杂的关系映射和查询功能,适用于简单的数据操作场景。

示例代码:

// 查询数据
using (var db = new Database("connectionString"))
{
		var products = db.Query<Product>("SELECT * FROM Products WHERE Price > @0", 10);
}
// 插入数据
using (var db = new Database("connectionString"))
{
    var newProduct = new Product { Name = "New Product", Price = 20 };
    db.Insert(newProduct);
}

以上是几种常见的.NET ORM框架,每种框架都有其特点和适用场景。选择合适的框架需要根据项目需求、团队经验和个人偏好来决定。如果需要更高级的功能和更好的性能,可以考虑使用商业级的ORM框架,如Entity Framework Core、LLBLGen Pro等。如果对性能要求较高,可以考虑使用轻量级的框架,如Dapper、PetaPoco等。



Tags:ORM框架   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
.NET Core下有热门的ORM框架使用方法
.NET Core下有很多热门的ORM框架,以下是其中六个常用的框架,包括EF Core、Dapper、NHibernate、Fluent NHibernate、LLBLGen Pro和PetaPoco。接下来,我将为您详细介绍每个框架...【详细内容】
2023-11-16  Search: ORM框架  点击:(160)  评论:(0)  加入收藏
Java革命性ORM框架Jimmer简单介绍
本文使用Jimmer的官方用例来介绍Jimmer的使用方法,Jimmer同时支持Java和Kotlin,本文使用Java来介绍,实际上Kotlin比Java使用起来更方便,这里为了方便大家理解,使用Java来介...【详细内容】
2023-05-28  Search: ORM框架  点击:(317)  评论:(0)  加入收藏
横空出世!MyBatis-Plus同款ES ORM框架,用起来够优雅
使用过Spring Data操作ES的小伙伴应该有所了解,它只能实现一些非常基本的数据管理工作,一旦遇到稍微复杂点的查询,基本都要依赖ES官方提供的RestHighLevelClient,Spring Data只...【详细内容】
2022-10-11  Search: ORM框架  点击:(402)  评论:(0)  加入收藏
Python元类实战,通过元类实现数据库ORM框架
今天是Python专题的第19篇文章,我们一起来用元类实现一个简易的ORM数据库框架。本文主要是受到了廖雪峰老师Python3入门教程的启发,不过廖老师的博客有些精简,一些小白可能看起...【详细内容】
2020-06-26  Search: ORM框架  点击:(251)  评论:(0)  加入收藏
从ORM框架,聊一聊数据库的设计
浅谈ORM我是搞C#的菜鸟(别喷),但是编程思想都是想通的。何不如听一听我这个C#程序员的编程思考呢?只接触过EF和SqlSugar,正在做的项目用到的就是国产的SqlSugar,个人感觉写法...【详细内容】
2019-09-03  Search: ORM框架  点击:(847)  评论:(0)  加入收藏
数据库ORM框架:Mybatis九种sql实操方式,你get到了吗?
现在越来越流行基于Springboot开发web应用,其中利用mybatis作为数据库CRUD操作已成为主流,楼主总结了九大类使用mybatis操作数据库sql小技巧分享给大家。 分页查询 预置sql...【详细内容】
2019-08-28  Search: ORM框架  点击:(862)  评论:(0)  加入收藏
▌简易百科推荐
Web Components实践:如何搭建一个框架无关的AI组件库
一、让人又爱又恨的Web ComponentsWeb Components是一种用于构建可重用的Web元素的技术。它允许开发者创建自定义的HTML元素,这些元素可以在不同的Web应用程序中重复使用,并且...【详细内容】
2024-04-03  京东云开发者    Tags:Web Components   点击:(7)  评论:(0)  加入收藏
Kubernetes 集群 CPU 使用率只有 13% :这下大家该知道如何省钱了
作者 | THE STACK译者 | 刘雅梦策划 | Tina根据 CAST AI 对 4000 个 Kubernetes 集群的分析,Kubernetes 集群通常只使用 13% 的 CPU 和平均 20% 的内存,这表明存在严重的过度...【详细内容】
2024-03-08  InfoQ    Tags:Kubernetes   点击:(12)  评论:(0)  加入收藏
Spring Security:保障应用安全的利器
SpringSecurity作为一个功能强大的安全框架,为Java应用程序提供了全面的安全保障,包括认证、授权、防护和集成等方面。本文将介绍SpringSecurity在这些方面的特性和优势,以及它...【详细内容】
2024-02-27  风舞凋零叶    Tags:Spring Security   点击:(52)  评论:(0)  加入收藏
五大跨平台桌面应用开发框架:Electron、Tauri、Flutter等
一、什么是跨平台桌面应用开发框架跨平台桌面应用开发框架是一种工具或框架,它允许开发者使用一种统一的代码库或语言来创建能够在多个操作系统上运行的桌面应用程序。传统上...【详细内容】
2024-02-26  贝格前端工场    Tags:框架   点击:(46)  评论:(0)  加入收藏
Spring Security权限控制框架使用指南
在常用的后台管理系统中,通常都会有访问权限控制的需求,用于限制不同人员对于接口的访问能力,如果用户不具备指定的权限,则不能访问某些接口。本文将用 waynboot-mall 项目举例...【详细内容】
2024-02-19  程序员wayn  微信公众号  Tags:Spring   点击:(39)  评论:(0)  加入收藏
开发者的Kubernetes懒人指南
你可以将本文作为开发者快速了解 Kubernetes 的指南。从基础知识到更高级的主题,如 Helm Chart,以及所有这些如何影响你作为开发者。译自Kubernetes for Lazy Developers。作...【详细内容】
2024-02-01  云云众生s  微信公众号  Tags:Kubernetes   点击:(50)  评论:(0)  加入收藏
链世界:一种简单而有效的人类行为Agent模型强化学习框架
强化学习是一种机器学习的方法,它通过让智能体(Agent)与环境交互,从而学习如何选择最优的行动来最大化累积的奖励。强化学习在许多领域都有广泛的应用,例如游戏、机器人、自动驾...【详细内容】
2024-01-30  大噬元兽  微信公众号  Tags:框架   点击:(67)  评论:(0)  加入收藏
Spring实现Kafka重试Topic,真的太香了
概述Kafka的强大功能之一是每个分区都有一个Consumer的偏移值。该偏移值是消费者将读取的下一条消息的值。可以自动或手动增加该值。如果我们由于错误而无法处理消息并想重...【详细内容】
2024-01-26  HELLO程序员  微信公众号  Tags:Spring   点击:(84)  评论:(0)  加入收藏
SpringBoot如何实现缓存预热?
缓存预热是指在 Spring Boot 项目启动时,预先将数据加载到缓存系统(如 Redis)中的一种机制。那么问题来了,在 Spring Boot 项目启动之后,在什么时候?在哪里可以将数据加载到缓存系...【详细内容】
2024-01-19   Java中文社群  微信公众号  Tags:SpringBoot   点击:(86)  评论:(0)  加入收藏
花 15 分钟把 Express.js 搞明白,全栈没有那么难
Express 是老牌的 Node.js 框架,以简单和轻量著称,几行代码就可以启动一个 HTTP 服务器。市面上主流的 Node.js 框架,如 Egg.js、Nest.js 等都与 Express 息息相关。Express 框...【详细内容】
2024-01-16  程序员成功  微信公众号  Tags:Express.js   点击:(85)  评论:(0)  加入收藏
站内最新
站内热门
站内头条