EntityFramework默认映射规则
我不太习惯通过CodeFirst去维护数据库(尽管这是未来实现自动编程的必经之路),还是喜欢通过数据库设计工具如PowerDesigner去建表。如果不想对EF的实体和数据表做什么映射的话,就要注意默认映射规则。以订单表(Order)和订单明细表(OrdersDetails)这类一对多的关系表为例。
数据库建表脚本:
create table Orders
(
id ,),
OrderNo nvarchar(),
TotalAmount ,),
OrderTime datetime default getdate()
)
create table OrdersDetails
(
id ,),
Orders_Id int,
Product_Id int,
ProductName nvarchar(),
AddTime datetime default getdate()
)
create table Product
(
id ,),
name nvarchar(),
)
insert into Orders(OrderNo,TotalAmount) values();
insert into Orders(OrderNo,TotalAmount) values();
insert into Orders(OrderNo,TotalAmount) values();
insert into Orders(OrderNo,TotalAmount) values();
insert into Orders(OrderNo,TotalAmount) values();
insert into OrdersDetails(Orders_Id,Product_Id,ProductName) values(,,'Iphone8');
insert into OrdersDetails(Orders_Id,Product_Id,ProductName) values(,,'MI6');
insert into OrdersDetails(Orders_Id,Product_Id,ProductName) values(,,'HW7');
insert into OrdersDetails(Orders_Id,Product_Id,ProductName) values(,,'MZ');
insert into Product(Name) values('Iphone8');
insert into Product(Name) values('MI6');
insert into Product(Name) values('HW7');
insert into Product(Name) values('MZ');
总结的几个规则:
1.明细表的表明要用复数形式即 OrdersDetails
2.外键关系要 关联表名称_Id:Orders_Id,即使实体类是OrdersId也是去查找Orders_Id列
3.除了关联外键外其他字段最好用驼峰式命名,不要包含_或-
实体类和DbContext如下:
public class OrderManamgerDBContext : DbContext
{
public DbSet<Orders> Orders { get; set; }
public DbSet<OrdersDetails> OrdersDetails { get; set; }
public OrderManamgerDBContext() { }
public OrderManamgerDBContext(string connectionString) : base(connectionString) { }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Configurations.Add(new OrdersDetailsConfiguration());
base.OnModelCreating(modelBuilder);
}
}
public class OrdersDetailsConfiguration : EntityTypeConfiguration<OrdersDetails>
{
public OrdersDetailsConfiguration()
{
//不是按照EF默认规则命名的需要手动映射
//HasEntitySetName("OrdersDetails");
//Property(t => t.OrdersId).HasColumnName("Orders_Id");
//Property(t => t.ProductId).HasColumnName("Product_Id");
}
}
public class Orders
{
public int id { get; set; }
public string OrderNo { get; set; }
public decimal TotalAmount { get; set; }
public DateTime OrderTime { get; set; }
public List<OrdersDetails> OrdersDetail { get; set; }
}
public class OrdersDetails
{
public int id { get; set; }
public int Orders_Id { get; set; }
public int Product_Id { get; set; }
public string ProductName { get; set; }
public DateTime AddTime { get; set; }
}
如果实体类和数据表字段命名方式不一样就需要手动映射:
public class OrdersDetail
{
public int id { get; set; }
public int OrdersId { get; set; }
public int ProductId { get; set; }
public string ProductName { get; set; }
public DateTime AddTime { get; set; }
}
这个时候就要把DbContext中的注释放开
控制台程序,采用积极加载方式:
class EFTest
{
static OrderManamgerDBContext odmdb = new OrderManamgerDBContext("DbContext");
//static OrderManamgerDBContext odmdb = new OrderManamgerDBContext(ConfigurationManager.ConnectionStrings["DbContext"].ConnectionString);
public static void Main(string[] args)
{
);
//var rlt = odmdb.Orders.Where(od => od.id == 1);
foreach(var itm in rlt)
{
Console.WriteLine("单据编号 "+itm.OrderNo + "\r\n明细产品:");
foreach (var citm in itm.OrdersDetail)
{
Console.WriteLine(citm.ProductName);
}
}
string sql = rlt.ToString();
Console.Read();
}
}
建议能按照默认规则设计就按照默认规则设计,EF的一个初衷就是减少工作量
EntityFramework默认映射规则的更多相关文章
- 使用Logstash创建ES映射模版并进行数据默认的动态映射规则
本文配置为 ELK 即(Elasticsearch.Logstash.Kibana)5.5.1. Elasticsearch 能够自动检测字段的类型并进行映射,例如引号内的字段映射为 String,不 ...
- SpringMVC注解汇总(二)-请求映射规则
接上一节SpringMVC注解汇总-定义 讲到Httpy请求信息 URL路径映射 1)普通URL路径映射 @RequestMapping(value={"/test1", &quo ...
- SpringMVC学习系列(3) 之 URL请求到Action的映射规则
在系列(2)中我们展示了一个简单的get请求,并返回了一个简单的helloworld页面.本篇我们来学习如何来配置一个action的url映射规则. 在系列(2)中我们在HelloWorldContr ...
- EntityFramework 实体映射到数据库
EntityFramework实体映射到数据库 在Entity Framework Code First与数据表之间的映射方式实现: 1.Fluent API映射 通过重写DbContext上的OnM ...
- SpringMVCURL请求到Action的映射规则
SpringMVC学习系列(3) 之 URL请求到Action的映射规则 在系列(2)中我们展示了一个简单的get请求,并返回了一个简单的helloworld页面.本篇我们来学习如何来配置一个acti ...
- Springboot学习02-webjars和静态资源映射规则
Springboot学习01-webjars和静态资源映射规则 前言 1-以前我们在IDEA中创建一个项目,添加web依赖包,我们现在是一个web应用,应该在man目录下面有一个webapp文件夹,将 ...
- 配置AutoMapper映射规则《转》
配置AutoMapper映射规则 AutoMapper是基于约定的,因此在实用映射之前,我们需要先进行映射规则的配置. public class Source { public int SomeVal ...
- go培训课程都学什么?xorm框架学习系列(二):xorm结构体映射规则和表操作
上节内容我们学习了基本的xorm框架的知识和基础配置的相关信息.本节课内容我们继续学习相关的知识和相关操作. 名称映射规则 名称映射规则主要负责结构体名称到表名和结构体field到表字段的名称映射. ...
- SpringCloud Zuul 路由映射规则配置
阅读目录 前言 快速入门 路由详解 Cookie与头信息 本地跳转 Hystrix和Ribbon支持 过滤器解释 动态加载 后记 回到目录 前言 本文起笔于2018-06-26周二,接了一个这周要完成 ...
随机推荐
- ubuntu12.04 安装中文输入法
1. 安装输入法的第一步,是安装语言包.我们选择System Settings-->Language Support-->Install/Remove Languages 选择中文 2. ...
- 例子:web版坦克大战1.0
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 3D轮播切换特效 源码
这个3D轮播切换特效是我2017年2月份写的 当初我 刚接触HTML不久,现在把源码分享给大家 源码的注释超级清楚 . <!-- 声明文档类型:html 作用:符合w3c统一标准规范 每个浏览器 ...
- jmeter测试
时间过得飞快,转眼间就到了公司半个月了,这是第三周上班,从上班到现在感觉自己什么都没有做,只是写了一些前台的验证,况且我的前台并不是很熟,js学了很久也快忘记了,看了看插件也不咋会用,但是自己也写了点 ...
- PHP 微信分享页面(图文)
首先确保你的公众号配置没有问题,详细请看: PHP 微信公众号-创建菜单-配置 1.获取签名包 这里需要你的appid 和 开发者密码 //获取签名包 public function getSignP ...
- 【转】sublime text 3 显示空格和Tab
因为sublime text3确实太好用了所以也用它写代码了,可是在Python3第一步把preferences.sublime-setting-Default里面的"draw_white_ ...
- python并发编程之多线程
一 同步锁 注意: 1线程抢的是GIL锁,GIL锁就是执行权限,拿到权限后才能拿到互斥锁Lock,但是如果发现Lock没有被释放而阻塞,则立即交出拿到的执行权. 2join是等待所有,即整体串行,而 ...
- DeepLearning.ai学习笔记(四)卷积神经网络 -- week2深度卷积神经网络 实例探究
一.为什么要进行实例探究? 通过他人的实例可以更好的理解如何构建卷积神经网络,本周课程主要会介绍如下网络 LeNet-5 AlexNet VGG ResNet (有152层) Inception 二. ...
- Python 浅析线程(threading模块)和进程(process)
线程是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务 进程与线程 什么 ...
- 大白话说Java泛型(一):入门、原理、使用
文章首发于[博客园-陈树义],点击跳转到原文<大白话说Java泛型(一):入门.原理.使用> 远在 JDK 1.4 版本的时候,那时候是没有泛型的概念的.当时 Java 程序员们写集合类的 ...