【.Net开发】之Entity Framework Core
程序员文章站
2024-01-21 20:30:28
...
前言:以下内容来源于微软官方文档。
Entity Framework (EF) Core 是轻量化、可扩展、开源和跨平台版的常用 Entity Framework 数据访问技术。
EF Core 可用作对象关系映射程序 (O/RM),以便于 .NET 开发人员能够使用 .NET 对象来处理数据库,这样就不必经常编写大部分数据访问代码了。
EF Core 支持多个数据库引擎。
模型
对于 EF Core,使用模型执行数据访问。 模型由实体类和表示数据库会话的上下文对象构成,可便于用户查询和保存数据。
可以根据现有数据库生成模型,手动将模型编码为与数据库匹配,也可以使用 EF 迁移根据模型创建数据库,然后在模型随时间推移发生更改时改进它。
using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
namespace Intro
{
public class BloggingContext : DbContext
{
public DbSet<Blog> Blogs { get; set; }
public DbSet<Post> Posts { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlServer(
@"Server=(localdb)\mssqllocaldb;Database=Blogging;Integrated Security=True");
}
}
public class Blog
{
public int BlogId { get; set; }
public string Url { get; set; }
public int Rating { get; set; }
public List<Post> Posts { get; set; }
}
public class Post
{
public int PostId { get; set; }
public string Title { get; set; }
public string Content { get; set; }
public int BlogId { get; set; }
public Blog Blog { get; set; }
}
}
查询
使用语言集成查询 (LINQ) 从数据库检索实体类的实例。
using (var db = new BloggingContext())
{
var blogs = db.Blogs
.Where(b => b.Rating > 3)
.OrderBy(b => b.Url)
.ToList();
}
保存数据
使用实体类的实例在数据库中创建、删除和修改数据。
using (var db = new BloggingContext())
{
var blog = new Blog { Url = "http://sample.com" };
db.Blogs.Add(blog);
db.SaveChanges();
}
推荐阅读
-
动态网站开发技术学习3:ASP.NET内置对象之Response对象
-
.NET Entity Framework (with Oracle ODP.NET) -Code First
-
记录.NET Core部署到Linux之发布项目到Linux(2)
-
ASP.NET Core - Razor页面之Handlers处理方法
-
循序渐进学.Net Core Web Api开发系列【16】:应用安全续-加密与解密
-
让ADO.NET Entity Framework 支持ACCESS数据库
-
从壹开始前后端分离【 .NET Core2.0 +Vue2.0 】框架之十三 || DTOs 对象映射使用,项目部署Windows+Linux完整版,
-
.NET Core系列之MemoryCache 缓存域
-
.NET Core系列之MemoryCache 缓存过期
-
asp.net core参数保护之自定义要保护的参数类型