小白学习之Code First(四)
code first :约定大于配置(通过配置实体重写约定)
通过两种方式配置实体:DataAnnotations Fluent Api
System.ComponentModel.DataAnnotations命名空间中只定义了部分实体验证的特性,在EntityFramework程序集中定义了更多的数据映射特性
DataAnnotations是基于实体配置的一些简单的特性,所在命名空间:System.ComponentModel.DataAnnotations
- KeyAttribute:对数据库中表的主键的设置
- RequiredAttribute:对应数据库中字段的数据是否可以为null
- MaxLengthAttribute:对应数据库中字符串类型字段的最大长度
- MinLengthAttribute:在数据库中无对应,但在代码中字符串最小长度
- ConcurrencyCheckAttribute:指定用于开放式并发检查的列的数据类型,用于任何数量任何类型的属性中
- TimestampAttribute:将列的数据类型指定为行版本,只能用于单字节类型的属性中
- DatabaseGeneratedAttribute:标记指定实体属性是由数据库生成的,并指定生成策略(None数据库不生成值,Identity当插入行时,数据库生成值,Computed当插入或更新行时,数据库生成值),此属性是只读的。可用来映射成自动增长列
- ColumnAttribute:指定实体属性在数据库中的列名及数据类型
- TableAttribute:指定实体类对应的数据表名
- ForeignKeyAttribute:指定导航属性的外键字段
- NotMappedAttribute:标记指定实体属性在创建数据库中不创建对应字段
- ComplexTypeAttribute:标记指定实体属性是将一个对象作为另一个对象的属性,映射到数据库中则子对象表现多个属性字段
- StringLengthAttribute:在数据字段中指定最大和最小的字符长度
- IndexAttribute:创建索引
- InversePropertyAttribute:用在类之间有多重关系的时候
对于实体关系对应的数据表关系,无非“0:1,1:1,0:N,1:N,N:N”这几种,可以使用导航属性中的数据类型来表示,0…1端使用单个实体类型表 示,N端使ICollection<T>集合类型表示.对于单实体端,默认是可为空的,即为0关系,如果要设置为1关系,要使用 [Required]标签来进行标记。但对于一对一中的关系主体与依赖对象确无法做更细节的控制.DataAnnotations可以同时在同一个类后者属性上使用多个标记属性.
例子:
[Table("Student")]//生成数据库对应的Student表
public class StudentInfo
{
[Key]//即使属性不是以Id或者类名+id命名的 也会把SKey创建为主键 ,单个主键为自动增长
public int SKey { get; set; }
public string Name { get; set; }
public char Gender { get; set; }
public DateTime Birth { get; set; }
//public ClassInfo ClassInfo { get; set; }
//public Teacher Teacher { get; set; }
}

复合主键:指定主键列的顺序[Column(Order=1)],复合主键不自增
[Table("Student")]//生成数据库对应的Student表
public class StudentInfo
{
[Key]
[Column(Order =)]
public int SKey { get; set; }
[Key]
[Column(Order =)]
public int SKey1 { get; set; }
public string Name { get; set; }
public char Gender { get; set; }
public DateTime Birth { get; set; }
//public ClassInfo ClassInfo { get; set; }
//public Teacher Teacher { get; set; }
}

同样还使用到Table和Column特性的用法。
[Table("Student",Schema ="ray")]//生成数据库对应的Student表
public class StudentInfo
{
[Key]
[Column(Order =)]
public int SKey { get; set; }
//[Key]
//[Column(Order =2)]
//public int SKey1 { get; set; }
//[Required]
//[MaxLength(40),MinLength(4)]
public string Name { get; set; }
[Column("性别",TypeName ="Nvarchar()")]
public char Gender { get; set; }
[Required(AllowEmptyStrings =true),StringLength()]
public string Mark { get; set; }
[NotMapped]
public int Age { get; set; }
public DateTime Birth { get; set; }
[Timestamp]
public byte[] RowVersion { get; set; }
//只读和只写属性不会创建数据库列
public int Nokey1 { get { return ; } }
public int Nokey2 { set { value = ; } }
public int CID { get; set; }
[ForeignKey("CID")]
public ClassInfo ClassInfo { get; set; }
//public Teacher Teacher { get; set; }
}
public class ClassInfo
{
[Key]
public int ID { get; set; }
public string Name { get; set; }
//每班都有很多学生
public ICollection<StudentInfo> Students { get; set; }
//public ICollection<Teacher> Teachers { get; set; }
}
小白学习之Code First(四)的更多相关文章
- Python小白学习之路(四)——第一次练习题
写在前面: 今天下雪了呢!连着两天都没有更新学习记录. 我没有偷懒呢.做了一天的练习题,昨天学的内容还没总结完,太累了就回去睡觉了 连续一周早起,强大的内心也无法支撑我疲惫的身体 今天早起做了整理.加 ...
- 小白学习之Code First(三)
上下文Context类中的base构造器的几个方法重置(1.无参 2.database name 3 . 连接字符串) 无参:如果基类base方法中无参,code first将会以 :{Namespa ...
- 小白学习之Code First(二)
Code First约定: 注:EDMX模板 (SSDL:存储模型=>数据库表 ,CSDL:概念模型=>实体,C-S模型=>存储和概念模型之间的映射关系) System.Data.E ...
- 小白学习之Code First(一)
1.根据自己的理解,Code First :通过实体类和相关配置生成对应的数据库,实现实体和数据库的映射关系,或通过实体类和相关配置与已经生成的实体与已经存在的数据库搭建映射关系 例: 实体类:Stu ...
- 小白学习安全测试(四)——扫描工具-Vega
WEB扫描工具-Vega 纯图形化界面,Java编写的开源web扫描器.两种工作模式:扫描模式和代理模式[主流扫描功能].用于爬站.处理表单,注入测试等.支持SSL:http://vega/ca.cr ...
- 小白学习之Code First(五)
Fluent API:另一种配置实体类的方式,它比DataAnnorations提供了更多的配置 其中EntityTypeConfiguration这个类提供了重要的属性.方法来配置对应的实体类,可以 ...
- 【Unity Shaders】学习笔记——SurfaceShader(四)用纹理改善漫反射
[Unity Shaders]学习笔记——SurfaceShader(四)用纹理改善漫反射 转载请注明出处:http://www.cnblogs.com/-867259206/p/5603368.ht ...
- Python小白学习之函数装饰器
装饰器 2018-10-25 13:49:37 装饰器从字面意思就是用来装饰的,在函数可以理解为:在函数中,我们不想影响原来的函数功能,又想给函数添加新的功能,这时候我们就用到了装饰器. 一般函数操作 ...
- USB小白学习之路(10) CY7C68013A Slave FIFO模式下的标志位(转)
转自良子:http://www.eefocus.com/liangziusb/blog/12-11/288618_bdaf9.html CY7C68013含有4个大端点,可以用来处理数据量较大的传输, ...
随机推荐
- [工具]JSON校验、转换在线工具
1. 在线JSON代码检验.检验.美化.格式化工具[简单易用的格式化工具]: http://tools.jb51.net/code/json 2. JSON在线格式化工具[代码高亮及可控缩进大小的格式 ...
- Ubuntu-18.04.2系统 Nginx+uWSGI+Django 部署生产环境
首先准备环境: 1.使用虚拟机 VMware Workstation Pro (也可以不用),安装Ubuntu-18.04.2系统 开始搭建环境 (因为ubuntu18.4.2集成了python3.6 ...
- WPF 重写微调自带的样式,ListView、DataGrid、TreeView等所有控件的默认样式
不知道各位在开发中有没有遇到这样的窘迫,开发一个UI,设计给出的效果图和自带的样式的区别很大,然后有的样式通过属性是修改不了的,比如TreeView的子项TreeViewItem,想完全透明背景色就做 ...
- Validation failed for one or more entities. See ‘EntityValidationErrors’ property for moredetails[转]
这里给大家介绍一个Exception类,让我们能够轻松的知道具体的哪一个字段出了什么问题. 那就是 System.Data.Entity.Validation.DbEntityValidationEx ...
- On extracting ops from LLVM backend
Symbols and ops generation: llvm::Function* BackendLLVM::build_llvm_instance (bool groupentry) Work ...
- disruptor调优方法
翻译自disruptor在github上的文档,https://github.com/LMAX-Exchange/disruptor/wiki/Getting-Started Basic Tuning ...
- s11 day104 数据库表结构与立即支付流程
数据库表结构: 13张 1. 课程大类 2.课程子类 3.学位课程 4.老师表 5.奖学金 6.专题课 7.课程详情 8.课程大纲 9.常见问题 10.章节 11.课时 12.作业表 13.价格策略 ...
- 带你走进php大马的结构模块编写之路
本文原创作者:Laimooc 第一部分:前沿综述 本次我主要写了[文件的创建].[文件的删除].[文件的上传].[目录浏览].[命令执行]小模块,以及[组合的目录浏览和文件删除功能]的模块: 实验环境 ...
- Youke365_2_4 一处Sql注入漏洞以及一处任意文件删除
本文作者:X_Al3r Prat 0 自白 每一天都是新的一天.没啥吐槽的,步入正题 /system/category.php 文件一处Sql注入## 80-87行代码 $root_i ...
- [bug]微信小程序使用 <scroll-view> 和 box-shadow 引起页面抖动
背景 为了实现点点点动态loading效果,并且方便使用(只需要给一个空元素加一个.loading),有如下代码: .loader { background-color: #fff; font-siz ...