对于SQL Server、MySql、Oracle等这些传统的数据库,基本都是关系型数据库,都是体现实体与实体之间的联系,在以前开发时,可能先根据需求设计数据库,然后在写Model和业务逻辑,对于Model类基本都是和表的字段对应着,而表中存的每条记录又和类的实例对象对应着,有了这个对照关系,就是能不能只在一边设计,在数据库设计表或在VS中设计Model,然后直接生成另一边,这样就省了好多时间成本。于是有了ORM,Object Relation Mapping,对象关系映射。既然可以根据Model可以生成数据库,数据库也可以生成Model,Model、数据库又是分离的,我们也可以根据Model生成不同类型(Sql Server\Oracle)数据库,而不同类型的数据库(Sql Server\Oracle)也可以生成同样的Model,而它们共同的纽带就是Mapping。

EF实体框架有3种类型,Data First、Model First、Code First。从今天起,将来的几篇博客可能都是关于Code First的,可能有人会问,其他的呢?对于另外两个我不打算花太多的时间,现在code first用的比较多,而且和其他两个比来说更加方便简单,code first没有包含CSDL(Conceptual Schema Definition Language 概念架构定义语言)、SSDL(Store Schema Definition Language存储架构定义语言)、MSL(Mapping Specification Language 映射规范语言)的映射定义,可是使用基于约定的映射。例如主键,只需要用Id命名属性或以Id结尾,这种会自动映射到主键上。对于上面的CSDL、SSDL、MSL根据中文应该也能猜出一二来,其实CSDL概念架构定义语言,定义概念的嘛,当然是定义.Net类的,而SSDL存储架构定义,既然是存储,肯定是数据库啊,所以它是描述表及其关系的结构。而MSL映射规范语言,当然是用来映射的,比如类中的Name属性可能在数据库定义的列名不是name,那怎么办呢?这时有了MSL就好办了,它就是用来描述映射关系的。

上面瞎逼逼半天,实际上今天是想大致演示下code first的用法,做简单的增删改查。

一、Model

首先是创建了一个控制台应用程序EFCodeFirstDemo,又创建了一个存放Model的类库EFCodeFirstDemo,以及一个与数据库有关系的类库EFCodeFirstDataAccess,算是三层架构中的DAL,至于BLL先不创建,只是简单的演示。既然是code first,管理对象,那肯定要先有一个Model类,这里在EFCodeFirstDemo中定义了一个Student类。在Student类中使用约定定义StuId为主键,由于默认会把Id结尾的属性作为主键,所以不用特性也可以。

大学生就业培训,高中生培训,在职人员转行培训,企业团训

using System;using System.Collections.Generic;using System.ComponentModel.DataAnnotations;using System.Linq;using System.Text;using System.Threading.Tasks;namespace EFCodeFirstModels
{    public class Student
    {
        [Key]        public string StuId { get; set; }        public string Name { get; set; }      &nb