Code First 二 DataAnnotation 数据注解
Code-First中配置域类
我们在前一节学习了默认的代码优先约定。Code-First使用默认约定从您的域类构建概念模型。Code-First利用称为约定而不是配置的编程模式。这意味着您可以通过配置您的域类来为EF提供所需的信息来覆盖这些约定。有两种方法来配置您的域类。
- DataAnnotations
- 流利的API
DataAnnotation
DataAnnotation是一个简单的基于属性的配置,您可以将其应用于您的域类及其属性。您可以在System.ComponentModel.DataAnnotations命名空间中找到大多数属性。但是,DataAnnotation仅提供Fluent API配置的一个子集。因此,如果您在DataAnnotation中找不到某些属性,则必须使用Fluent API进行配置。
例如:
我们后面详讲。
EF 6和EF Core中的数据注释属性:
数据注释属性是可以应用于实体类或属性的.NET属性,以覆盖EF 6和EF Core中的默认约定。
数据注解的属性被包括在System.ComponentModel.DataAnnotations
和System.ComponentModel.DataAnnotations.Schema
中EF 6以及EF核心的命名空间。这些属性不仅在实体框架中使用,而且还可以用于ASP.NET MVC或数据控件。
这些数据注释属性在EF 6和EF Core中以相同的方式工作,并且在两者中都是有效的。
Table
按照默认约定,EF 6创建与上下文类中的< DbSet <TEntity>属性名称> + s(或es)匹配的表名,EF Core创建与DbSet<TEntity>
属性名称相同名称的Db列。
表格属性: [Table(string name, Properties:[Schema = string])
- 名称:Db表的名称。
- 架构:应在其中创建指定表的Db架构的名称。(可选的)
Column 列设置
按照EF 6和EF Core中的默认约定,它会在数据库表中创建一个与属性名称相同名称和顺序的列。
列属性: [Column (string name, Properties:[Order = int],[TypeName = string])
- 名称:数据库表中列的名称。
- 顺序:以零索引开始的列的顺序。(可选的)
- TypeName:列的数据类型。(可选的)
Key 主键
默认约定为名称为Id
或的属性创建主键列<Entity Class Name>Id
。Key属性重写此默认约定。
在EF 6中,Key属性和Column属性可以应用于将在数据库中创建复合主键列的实体类的多个属性。EF Core不支持使用Key属性创建组合键。您必须HasKey()
在EF Core中使用Fluent API 函数。
NotMapped 不映射
默认情况下,EF为实体类中的每个属性(必须具有;&set;)创建一个列。该[NotMapped]
属性重写此默认约定。您可以申请[NotMapped]
对您做一个或多个属性的属性不希望在一个数据库表中创建一个相应的列。
ForeignKey 外键
按照默认约定,当EF的名称与相关实体的主键属性匹配时,EF将其作为外键属性。
外键签名: [ForeignKey(name string)]
- 名称:关联的导航属性的名称或关联的外键的名称。
[ForeignKey]
属性重写外键的默认约定它允许我们在依赖实体中指定名称与主体实体的主键属性不匹配的外键属性。
[ForeignKey(name)]
属性可以以三种方式应用:
[ForeignKey(NavigationPropertyName)]
在依赖实体中的外键标量属性上[ForeignKey(ForeignKeyPropertyName)]
在相关实体中的相关参考导航属性上[ForeignKey(ForeignKeyPropertyName)]
在主体实体的导航属性上
[ForeignKey]对依赖实体中的外键属性 ForeignKey("属性名")
实体的外键属性和相关导航属性名可以被指定作为参数
[ForeignKey]在依赖实体的导航属性中
应用于导航属性,并且可以指定相关的外键属性名称,
[ForeignKey]主要实体中的导航属性:
应用于主体实体中的导航属性,相关的外键属性名称可以在从属实体中指定
InverseProperty
当两个实体有多个关系时,使用InverseProperty属性。
遇到多个对象关系,这样是无法确定那个对应那个的
它自己不能识别,我们就手动让他们配对就行了,[InverseProperty]
属性应用于两个集合导航属性,OnlineCourses
并ClassRoomCourses
在Course
实体中指定其相关的导航属性
您可以使用[ForeignKey]
attribute来配置外键名称
Required 非空验证
必需的属性可以在实体类被施加到一个或多个属性。EF将在数据库表中为应用了该Required
属性的属性创建一个NOT NULL列。
MaxLength
MaxLength属性指定一个属性所允许的数据值的最大长度,该属性依次设置数据库中相应列的大小。它可以应用于实体的string
或byte[]
属性。
StringLength
StringLength属性可以应用于string
实体类的属性。它指定了字符串属性所允许的最大字符数,该字符串属性依次设置nvarchar
数据库中相应列(在SQL Server中)的大小。
timestamp
EF 6和EF Core都包含Timestamp数据注释属性。它只能在实体类中应用一次到字节数组类型的属性
注:时间戳在数据库中执行添加,更新,时间戳字段会自动的更新值
ConcurrencyCheck
数据库表中的相应列将用于开放式并发检查使用where
子句。EF将StudentName
在UPDATE语句中包含列来检查乐观并发性。
注意:时间戳属性只能应用于单个字节数组属性,而ConcurrencyCheck属性可以应用于任何数量的任何数据类型的属性。
Code First 二 DataAnnotation 数据注解的更多相关文章
- [ASP.NET MVC]笔记(二) 数据注解和验证
验证注解的使用 1.Required:必须字段 [Required] public string FirstName() { get; set; } 2.StringLength:长度限制,或是可选项 ...
- MVC-Model数据注解(二)-自定义
由于系统的数据注解肯定不适合所有的场合,所以有时候我们需要自定义数据注解. 自定义数据注解有两种,一种是直接写在模型对象中,这样做的好处是验证时只需要关心一种模型对象的验证逻辑,缺点也 ...
- 9.2 翻译系列:数据注解特性之---Column【EF 6 Code First系列】
原文链接:http://www.entityframeworktutorial.net/code-first/column-dataannotations-attribute-in-code-firs ...
- MVC5中Model层开发数据注解 EF Code First Migrations数据库迁移 C# 常用对象的的修饰符 C# 静态构造函数 MSSQL2005数据库自动备份问题(到同一个局域网上的另一台电脑上) MVC 的HTTP请求
MVC5中Model层开发数据注解 ASP.NET MVC5中Model层开发,使用的数据注解有三个作用: 数据映射(把Model层的类用EntityFramework映射成对应的表) 数据验证( ...
- Spring 3.1新特性之二:@Enable*注解的源码,spring源码分析之定时任务Scheduled注解
分析SpringBoot的自动化配置原理的时候,可以观察下这些@Enable*注解的源码,可以发现所有的注解都有一个@Import注解.@Import注解是用来导入配置类的,这也就是说这些自动开启的实 ...
- Entity Framework(三):使用特性(数据注解)创建表结构
一.理解Code First及其约定和配置 传统设计应用的方式都是由下而上的,即我们习惯优先考虑数据库,然后使用这个以数据为中心的方法在数据之上构建应用程序.这种方法非常适合于数据密集的应用或者数据库 ...
- ASP.NET MVC5----常见的数据注解和验证
只要一直走,慢点又何妨. 在使用MVC模式进行开发时,数据注解是经常使用的(模型之上操作),下面是我看书整理的一些常见的用法. 什么是验证,数据注解 验证 从全局来看,发现逻辑仅是整个验证的很小的一部 ...
- Linux内核--网络栈实现分析(二)--数据包的传递过程--转
转载地址http://blog.csdn.net/yming0221/article/details/7492423 作者:闫明 本文分析基于Linux Kernel 1.2.13 注:标题中的”(上 ...
- asp.net mvc3 数据验证(三)—自定义数据注解
原文:asp.net mvc3 数据验证(三)-自定义数据注解 前两节讲的都是asp.net mvc3预先设定的数据注解,但是系统自由的数据注解肯定不适合所有的场合,所以有时候我们需要 ...
随机推荐
- 基于Node.js的ghost开源博客平台
Ghost 是一套基于Node.js 构建的开源博客平台(Open source blogging platform),具有易用的书写界面和体验. 1.安装node windows 下安装npm:ht ...
- JavaEE中表现层、持久层、业务层的职责分析(转载)
表现层.持久层.业务层 注:本文转载于:http://www.blogjava.net/jiabao/archive/2007/04/08/109189.html 为了实现web层(struts)和持 ...
- Java通过jna调用c++动态库
1 环境准备 操作系统:windows 10,x64 jna,jna-4.4.0.jar c++开发环境,vc2013 java开发环境,eclipse,jdk8 2 dll开发 通过vc2013创建 ...
- 微软牛津计划——声纹识别与视频识别API上线啦!
上个月,我们发布了牛津计划机器学习的情感识别API,能够帮助不同平台的开发者轻松添加智能应用,而无需精通人工智能领域.牛津计划仅仅是微软在人工智能领域探索中的一个实例,而我们的期望是实现更加注重个人使 ...
- Oracle数据库从入门到精通 单行函数问题
视频课程:李兴华 Oracle从入门到精通视频课程 学习者:阳光罗诺 视频来源:51CTO学院 Oracle数据库从入门到精通-单行函数 在数据库中,为了方便用户的数据开发,往往会提供一系列的支持函数 ...
- JAVA程序员常用开发工具
1.JDK (Java Development Kit)Java开发工具集 SUN的Java不仅提了一个丰富的语言和运行环境,而且还提了一个免费的Java开发工具集(JDK).开发人员和最终用户可以利 ...
- IE Edge 下载文件的时候,文件名不能有windows不支持的特殊字符
IE Edge 下载文件的时候,文件名不能有windows不支持的特殊字符,比如:等. 马了个批的,其他浏览器包括IE就可以自动转换,比如:会自动变为_.
- Linux中redis的安装与配置
redis官网地址:http://www.redis.io/ redis安装 在Linux下安装Redis非常简单,这里以2.8.3版本为例,具体步骤如下: 1.下载源码,解压缩后编译源码. $ mk ...
- C/C++内存泄露检测
以下测试基于的gcc版本: gcc (Ubuntu 4.8.4-2ubuntu1~14.04) 4.8.4Copyright (C) 2013 Free Software Foundation, In ...
- My SQL 和SQL Server区别
MySQL 与SQL Server区别 今天了解了二者区别,整理网上查阅资料,总结列举如下: MSSQL == SQL server 是sybase与微软合作时期的产物. 对于程序开发人员而言,目前使 ...