微软跨平台ORM框架之EFCore — 约定与属性映射
EFCore中的约定简单来说就是规则,CodeFirst基于模型的约定来映射表结构。除此之外还有Fluent API、Data Annotations(数据注释) 可以帮助我们进一步配置模型。
按照这三者的优先级高低排序分别是:Fluent API、Data Annotations(数据注释)、约定。
1.约定
public class Person
{
public int ID { get; set; }
public int Age { get; set; }
public bool Status { get; set; }
public string Name { get; set; }
public DateTime CreateTime { get; set; }
}
1.1 主键约定
我们有这样的一个Person类,在实体中如果有名为ID的字段,或者实体名+ID的字段如:PersonID,那么EFCore生成的表会自动标识为主键。并且如果它的类型是int或Guid则会默认自增长。
映射之后的表结构:
我们可以看到C#中的int、bool、string、datetime,分别映射为 int,bit,navarchar(MAX),datetime2(7)。这是因为EFCore的默认约定是这么规定的。道友们可能会想自定义的映射,比如把string映射会varcher,datetime映射为datetime。嗯。。这就需要借助Fluent API或Data Annotations了。
1.2 外键约定
新建一个订单类,并添加Person类型的字段,以及PersonID(以类名+ID的形式),并在上下文中注册。EFCore在映射表时会根据我们给定Person类型和PersonID来添加外键约束。
public class Order
{
public Guid ID { get; set; }
public int PersonID { get; set; }
public Person Person { get; set; }
public string Address { get; set; }
public string Phone { get; set; }
}
修改Progarm.cs代码
class Program
{
static void Main(string[] args)
{ var context = new CoreDbContext();
// 删除数据库
context.Database.EnsureDeleted();
// 告诉EFCore我们要创建数据库
context.Database.EnsureCreated();
// 初始化数据
var person = new Person()
{
Name = "季某人",
Age = ,
Status = true,
CreateTime = DateTime.Now,
};
var person2 = new Person()
{
Name = "季某人",
Age = ,
Status = true,
CreateTime = DateTime.Now,
};
var order = new Order()
{
PersonID = ,
Address = "地球XX",
Phone = ""
};
context.Person.Add(person);
context.Person.Add(person2);
// 这里因为添加了外键,所以要先保存Person,不然会报外键的错误
context.SaveChanges();
context.Order.Add(order);
context.SaveChanges(); //Console.WriteLine("Hello World!");
}
}
启动项目,然后查看数据库。
可以看到数据完成了初始化,并且添加了外键约束。
2.Data Annotations(数据注释)
数据注释就是在属性上添加一些特性标签,告诉EFCore我们要映射的类型是什么样的,当默认的映射不能满足我们的需求时,就可以使用数据注释了。例如前面的映射,string类型映射为数据库的nvarchar(max),DateTime映射为datetime2(7)。 使用数据注释可以改变为我们想要映射成的类型,例如:string映射成varvhar。
添加一个新类OrderDetail,并添加数据注释。
public class OrderDetail
{
[Key] // 标识主键
public int ID { get; set; }
[Column(TypeName = "varchar(50)")] // 列的数据类型
[Required] // 必填列
public string Price { get; set; }
public DateTime? CreateTime { get; set; }
[Column("OrderCode")] // 列的显示名字
[StringLength()] // 列的长度
public string Code { get; set; }
public Guid? OrderID { get; set; } public Order Order { get; set; } }
启动项目,观察映射成的表结构。与实体中的配置一样。
基本常用的就这些,其他的用到的时候可以去官网文档上找。
3.Fluent API
Fluent API 相较于 数据注释更加灵活。它的配置需要写在自定义的上下文类中的OnModelCreating方法中。
比如改变表名,数据类型之类的
效果和数据注释是一样的,值得注意的是当Fluent API 和数据注释同时配置一个属性时,Fluent API会覆盖掉数据注释。
除了上述之外还可以利用Fluent API 统一表的命名规范:例如 "T_+实体名".
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
foreach (var item in modelBuilder.Model.GetEntityTypes())
{
modelBuilder.Entity(item.Name).ToTable("T_" + item.ClrType.Name);
}
}
遍历要映射的实体然后加上 "T_" 前缀。
具体差异可以观看微软EFCore文档,传送门:https://docs.microsoft.com/zh-cn/ef/core/modeling/relational/data-types
微软跨平台ORM框架之EFCore — 约定与属性映射的更多相关文章
- 微软跨平台ORM框架之EFCore
EFCore是微软推出的跨平台ORM框架,想较于EF6.X版本,更加轻量级.EFCore目前已经更新到2.x. 接下来用CodeFirst的方式来使用EFCore. 1.创建控制台程序 2.引入EFC ...
- c# 国内外ORM 框架 dapper efcore sqlsugar freesql hisql sqlserver数据常规插入测试性能对比
c# 国内外ORM 框架 dapper efcore sqlsugar freesql hisql sqlserver数据常规插入测试性能对比对比 在6.22 号发布了 c# sqlsugar,his ...
- 微软跨平台UI框架MAUI真的要来啦
.NET 6 preview已经上线,是时候为在BUILD 2020上宣布的新.NET Multi-platform App UI(MAUI)做准备了.对于客户端应用程序开发人员来说,这一年.NET有 ...
- Mego(2) - NET主流ORM框架分析
接上文我们测试了各个ORM框架的性能,大家可以很直观的看到各个ORM框架与原生的ADO.NET在境删改查的性能差异.这里和大家分享下我对ORM框架的理解及一些使用经验. ORM框架工作原理 典型ORM ...
- .NET 跨平台RPC框架DotNettyRPC Web后台快速开发框架(.NET Core) EasyWcf------无需配置,无需引用,动态绑定,轻松使用 C# .NET 0配置使用Wcf(半成品) C# .NET Socket 简单实用框架 C# .NET 0命令行安装Windows服务程序
.NET 跨平台RPC框架DotNettyRPC DotNettyRPC 1.简介 DotNettyRPC是一个基于DotNetty的跨平台RPC框架,支持.NET45以及.NET Standar ...
- .NET ORM框架HiSql实战-第一章-集成HiSql
一.引言 做.Net这么多年,出现了很多很多ORM框架,比如Dapper,Sqlsugar,Freesql等等.在之前的项目中,用到的ORM框架也大多数是这几个老牌的框架. 不过最近园子关于.NET ...
- 自定义ORM框架(转转)
ORM背景 在数据库界,主流的数据库都是关系型数据库,其采用的关系型数据结构模型,无论从数学上还是实践中都相当的成熟,得到非常广泛的应用.在关系型数据结构理 论中,所有的数据都组织成一个个相互独立的二 ...
- ORM框架之SQLALchemy
一.面向对象应用场景: 1.函数有共同参数,解决参数不断重用: 2.模板(约束同一类事物的,属性和行为) 3.函数编程和面向对象区别: 面向对象:数据和逻辑组合在一起:函数编程:数据和逻辑不能组合在一 ...
- EFCodeFirst属性映射约定
EFCodeFirst属性映射约定 EFCodeFirst 属性映射约定 CodeFirst与数据表之间得映射方式又两种:Data Annotation和Fluent API 默认约定: 表名为类名的 ...
随机推荐
- Markdown编辑器editor.md的使用---markdown上传图片
http://kindeditor.org/ 确定下有没有查找替换功能 http://pandao.github.io/editor.md/ http://pandao.github.io/edito ...
- java.exe进程来源排查录
解决后的一个小结:此处是一个tomcat端口,这种情况下,可以先在浏览器访问下看看效果,就可以快速定位 又发现一个简单的办法: 下面的定位过程,适用于各种场合 无意中发现有个进程开了好多端口,很奇怪 ...
- Javascript书籍推荐----(步步为赢)
在此分享一些高清javascript书籍,因为我也没有全部看完,所以在这只是推荐,不同的书适合不同的人,所有的书在网上均有电子书,若找不到,请在博客留言,我有大部分书籍的电子稿.希望有更多的好书分享出 ...
- index.go
package types type DocumentIndex struct { // 文本的DocId DocId uint64 // 文本的关键词长 TokenL ...
- SimpleDateFormat安全的时间格式化
SimpleDateFormat安全的时间格式化 想必大家对SimpleDateFormat并不陌生.SimpleDateFormat 是 Java 中一个非常常用的类,该类用来对日期字符串进行解析和 ...
- mysql主从复制搭建
1.准备工作: 准备一台主服务器,我的IP地址为192.168.13.138,和一台从服务器:192.168.13.137,数据库版本一致,主从库都建好相应的库和表: 2.修改主从服务器的mysql配 ...
- sdoi 2009 HH去散步 矩阵乘
如果没有题里的"不会立刻沿着刚刚走来的路走回"限制,那么直接矩乘计算k步的方案数 但加了这个限制,就不能以点来矩乘了,考虑边数<=60,如果以边建邻接矩阵呢?? 先拆边,再把 ...
- 深度学习与自动驾驶领域的数据集(KITTI,Oxford,Cityscape,Comma.ai,BDDV,TORCS,Udacity,GTA,CARLA,Carcraft)
http://blog.csdn.net/solomon1558/article/details/70173223 Torontocity HCI middlebury caltech 行人检测数据集 ...
- 【Python3爬虫】你会怎么评价复仇者联盟4?
一.写在前面 最近复仇者联盟4正在热映中,很多人都去电影院观看了电影,那么对于这部电影,看过的人都是怎么评价的呢?这时候爬虫就可以派上用场了! 二.主要思路 首先打开豆瓣电影,然后进入复仇者联盟4的详 ...
- typecho设置文章密码保护
在别人博客看到了一个需要输入密码才能访问文章的功能,像下图一样 typecho也是有这个功能,不需要插件就可以实现.在编辑文章时,右边高级选项,公开度里有个密码保护可以选择 效果图 不过这样的界面不是 ...