返回顶部
首页 > 资讯 > 精选 >ASP.NET Core中如何使用EF创建模型
  • 746
分享到

ASP.NET Core中如何使用EF创建模型

2023-06-29 22:06:58 746人浏览 八月长安
摘要

本文小编为大家详细介绍“asp.net Core中如何使用EF创建模型”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.net Core中如何使用EF创建模型”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一

本文小编为大家详细介绍“asp.net Core中如何使用EF创建模型”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.net Core中如何使用EF创建模型”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

1.必需和可选属性

如果实体属性可以包含null,则将其视为可选。如果属性的有效值不可以包含null,则将其视为必需属性。映射到关系数据库架构时,必需的属性将创建为不可为null的列,而可选属性则创建为可以为null的列。

1.1约定

按照约定,.NET 类型可以包含null的属性将配置为可选,而.NET类型不包含null的属性将根据需要进行配置。例如,具有.net值类型(int、decimal、bool等)的所有属性都是必需的,而具有可为null的.net值类型(int?、decimal?、bool?等)的所有属性都是配置为可选。

1.2数据批注

可以按如下所示将"约定"可以为"可选"的属性配置为"必需":

namespace EFModeling.DataAnnotations.Required{    class MyContext : DbContext    {        public DbSet<Blog> Blogs { get; set; }    }    public class Blog    {        public int BlogId { get; set; }        //加上这个批注,这个值就必需写入        [Required]        public string Url { get; set; }    }}

1.3Fluent api

namespace EFModeling.FluentAPI.Required{    class MyContext : DbContext    {        public DbSet<Blog> Blogs { get; set; }        protected override void OnModelCreating(ModelBuilder modelBuilder)        {            modelBuilder.Entity<Blog>()                .Property(b => b.Url)                //这个方法表示必需写入                .IsRequired();        }    }    public class Blog    {        public int BlogId { get; set; }        public string Url { get; set; }    }}

2.最大长度

配置最大长度可为数据存储提供有关要对给定属性使用的相应数据类型的提示。最大长度仅适用于数组数据类型,如string和byte[]。例如前端传统数据长度远大于限定的长度,则提示。

2.1约定

按照约定,应由数据库提供程序为属性选择适当的数据类型,即数据库字段设置长度多少,生产程序实体接受值时就限定长度多少。对于具有长度的属性,数据库提供程序通常将选择允许最长数据长度的数据类型。例如,Microsoft SQL Server将对字符string属性使用 nvarchar(max)(如果该列用作键,则会使用nvarchar(450))。

2.2数据批注

你可以使用数据批注为属性配置最大长度。此示例面向sql Server,因此使用数据类型 nvarchar(500)。

namespace EFModeling.DataAnnotations.MaxLength{    class MyContext : DbContext    {        public DbSet<Blog> Blogs { get; set; }    }    public class Blog    {        public int BlogId { get; set; }        //设置最大长度        [MaxLength(500)]        public string Url { get; set; }    }}

2.3Fluent API

namespace EFModeling.FluentAPI.MaxLength{    class MyContext : DbContext    {        public DbSet<Blog> Blogs { get; set; }        protected override void OnModelCreating(ModelBuilder modelBuilder)        {            modelBuilder.Entity<Blog>()                .Property(b => b.Url)                //设置最大长度                .HasMaxLength(500);        }    }    public class Blog    {        public int BlogId { get; set; }        public string Url { get; set; }    }}

3.并发标记

当我们发现生产环境某个实体字段经常处于并发当中,我们可以批注一下为并发字段。

3.1约定

按照约定,属性永远不会配置为并发标记。

3.2数据注释

您可以使用数据批注将属性配置为并发标记。

public class Person{   public int PersonId { get; set; }    //并发标记    [ConcurrencyCheck]    public string LastName { get; set; }    public string FirstName { get; set; }}

3.3Fluent API

您可以使用熟知的API将属性配置为并发标记。

class MyContext : DbContext{    public DbSet<Person> People { get; set; }    protected override void OnModelCreating(ModelBuilder modelBuilder)    {        modelBuilder.Entity<Person>()            .Property(p => p.LastName)            //并发标记            .IsConcurrencyToken();    }}public class Person{    public int PersonId { get; set; }    public string LastName { get; set; }    public string FirstName { get; set; }}

4.时间戳/行版本

时间戳是一个属性类型,在每次插入或更新行时,数据库都会生成一个新值。此该属性类型也被视为并发标记。这可以确保在你和其他人修改了行数据时你会收到异常信息。

4.1约定

按照约定,属性永远不会配置为时间戳。

4.2数据注释

你可以使用数据批注将属性配置为时间戳。

public class Blog{    public int BlogId { get; set; }    public string Url { get; set; }    //设置时间戳    1649324459    public byte[] Timestamp { get; set; }}

4.3Fluent API

你可以使用熟知的API将属性配置为时间戳。

class MyContext : DbContext{    public DbSet<Blog> Blogs { get; set; }    protected override void OnModelCreating(ModelBuilder modelBuilder)    {        modelBuilder.Entity<Blog>()            .Property(p => p.Timestamp)            //设置时间戳            .IsRowVersion();    }}public class Blog{    public int BlogId { get; set; }    public string Url { get; set; }    public byte[] Timestamp { get; set; }}

5.阴影属性

当数据库中的数据不应在映射的实体类型上公开时,阴影属性非常有用。它们最常用于外键属性,其中两个实体之间的关系由数据库中的外键值表示,但使用实体类型之间的导航属性在实体类型上管理关系,可以通过ChangeTracker API获取和更改影子属性值:

context.Entry(myBlog).Property("LastUpdated").CurrentValue = DateTime.Now;

可以通过EF.Property静态方法在LINQ查询中引用影子属性:

var blogs = context.Blogs.OrderBy(b => EF.Property<DateTime>(b, "LastUpdated"));

5.1约定

如果发现了关系,但在依赖实体类中找不到外键属性,则可以按约定创建阴影属性。在这种情况下,将引入阴影外键属性。影子外键属性将命名<navigation property name><principal key property name>为(指向主体实体的依赖实体上的导航用于命名)。如果主体键属性名称包含导航属性的名称,则该名称将只是<principal key property name>。如果依赖实体上没有导航属性,则会在其位置使用主体类型名称。
例如,下面的代码列表将导致BlogId Post向实体引入阴影属性。

class MyContext : DbContext{    public DbSet<Blog> Blogs { get; set; }    public DbSet<Post> Posts { get; set; }}public class Blog{    public int BlogId { get; set; }    public string Url { 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 Blog Blog { get; set; }}

5.2数据注释

不能通过数据批注创建阴影属性。

5.3Fluent API

你可以使用"熟知API"配置阴影属性。一旦你调用了Property方法的字符串重载,就可以链接到其他属性的任何配置调用。如果提供Property方法的名称与现有属性的名称相匹配(一个阴影属性或在实体类中定义的属性),则代码将配置该现有属性,而不是引入新的阴影属性。

class MyContext : DbContext{    public DbSet<Blog> Blogs { get; set; }    protected override void OnModelCreating(ModelBuilder modelBuilder)    {        modelBuilder.Entity<Blog>()            //创建阴影属性            .Property<DateTime>("LastUpdated");    }}public class Blog{    public int BlogId { get; set; }    public string Url { get; set; }}

读到这里,这篇“ASP.NET Core中如何使用EF创建模型”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: ASP.NET Core中如何使用EF创建模型

本文链接: https://lsjlt.com/news/326532.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • ASP.NET Core中如何使用EF创建模型
    本文小编为大家详细介绍“ASP.NET Core中如何使用EF创建模型”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET Core中如何使用EF创建模型”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一...
    99+
    2023-06-29
  • ASP.NET Core使用EF创建关系模型
    目录1.关系2.术语定义3.约定4.完全定义的关系5.无外键属性6.单个导航属性7.数据注释7.1ForeignKey7.2InverseProperty8.Fluent API8....
    99+
    2024-04-02
  • ASP.NET Core怎么使用EF创建模型
    这篇文章主要介绍“ASP.NET Core怎么使用EF创建模型”,在日常操作中,相信很多人在ASP.NET Core怎么使用EF创建模型问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ASP...
    99+
    2023-06-29
  • ASP.NET Core使用EF创建模型的方法
    这篇文章主要介绍“ASP.NET Core使用EF创建模型的方法”,在日常操作中,相信很多人在ASP.NET Core使用EF创建模型的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”A...
    99+
    2023-06-29
  • ASP.NET Core怎么使用EF创建关系模型
    今天小编给大家分享一下ASP.NET Core怎么使用EF创建关系模型的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧...
    99+
    2023-06-29
  • ASP.NET Core基于现有数据库创建EF模型
    1.简介 Entity Framework Core可通过数据库提供给应用程序的插件访问许多不同的数据库。我们可以通过使用Entity Framework Core构建执行基本数据访...
    99+
    2024-04-02
  • ASP.NET Core使用EF创建模型(索引、备用键、继承、支持字段)
    目录1.索引1.1约定1.2数据批注1.3Fluent API2.备用键2.1约定2.2数据注释2.3Fluent API3.继承3.1约定4.支持字段4.1约定4.2数据注释4.3...
    99+
    2024-04-02
  • ASP.NET Core如何使用EF为关系数据库建模
    本文小编为大家详细介绍“ASP.NET Core如何使用EF为关系数据库建模”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET Core如何使用EF为关系数据库建模”文章能帮助大家解决疑惑,下面跟着小编的思路...
    99+
    2023-06-29
  • ASP.NET Core使用EF为关系数据库建模
    目录1.简介2.表映射2.1约定2.2数据注释2.3Fluent API3.列映射3.1约定3.2数据注释3.3Fluent API4.数据类型4.1约定4.2数据注释4.3Flue...
    99+
    2024-04-02
  • ASP.NET Core使用EF创建模型(包含属性、排除属性、主键和生成值)
    目录1.什么是Fluent API?2.包含属性和排除属性2.1包含属性2.2排除属性2.2.1数据批注2.2.2Fluent API3.主键3.1数据批注3.2Fluent API...
    99+
    2024-04-02
  • ASP.NET Core MVC中的模型怎么使用
    本篇内容介绍了“ASP.NET Core MVC中的模型怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.模型绑...
    99+
    2023-06-30
  • ASP.NET Core 中FromServices如何使用
    本篇文章给大家分享的是有关 ASP.NET Core 中FromServices如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。构造函数...
    99+
    2024-04-02
  • ASP.NET Core中的NPM模块:如何使用它们?
    ASP.NET Core是一种跨平台的Web框架,它可以在Windows、Linux和macOS等各种操作系统上运行。在ASP.NET Core中,使用NPM模块可以轻松地添加各种功能和插件。本文将介绍如何在ASP.NET Core项目中...
    99+
    2023-08-25
    npm 数组 api
  • 如何在ASP.NET Core中使用HttpClientFactory
    目录为什么要使用 HttpClientFactory 使用 HttpClientFactory 注入 Controller ASP.Net Core 是一个开源的,跨平台的,轻量级模...
    99+
    2024-04-02
  • 如何在ASP.NET Core中使用ViewComponent
    目录前言自定义一个组件ViewComponent特性Taghelper方式Reference前言 在之前的开发过程中,我们对于应用或者说使用一些小的组件,通常使用分布页(parti...
    99+
    2024-04-02
  • 如何在ASP.Net Core中使用Serilog
    目录安装 Serilog使用 Serilog Sink使用 Serilog 替换原生的 Logger记录日志的一个作用就是方便对应用程序进行跟踪和排错调查,在实际应用上都是引入 日志...
    99+
    2024-04-02
  • Serilog如何在ASP.Net Core中使用
    本篇文章为大家展示了Serilog如何在ASP.Net Core中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。安装 Serilog使用 Visual Studio 新建 ASP.Net Cor...
    99+
    2023-06-14
  • 如何在Asp.Net Core中使用Refit
    本篇文章给大家分享的是有关如何在Asp.Net Core中使用Refit,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。ASP.NET 是什么ASP.NET 是开源,跨平台,高性...
    99+
    2023-06-07
  • ASP.NET Core中间件如何使用
    今天小编给大家分享一下ASP.NET Core中间件如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.前言...
    99+
    2023-06-29
  • Asp.Net Core中如何创建多DbContext并迁移到数据库
    这篇文章给大家分享的是有关Asp.Net Core中如何创建多DbContext并迁移到数据库的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  在我们的项目中我们有时候需要在我们的项目中创建DbContext,而...
    99+
    2023-06-07
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作