对于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的类库EFCodeFirstModels,以及一个与数据库有关系的类库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; } public int Age { get; set; } public Student(string stuId, string name, int age)
{
this.StuId = stuId;
this.Name = name;
this.Age = age;
}
//定义无参数的构造函数主要是因为在通过DbSet获取对象进行linq查询时会报错
//The class 'EFCodeFirstModels.Student' has no parameterless constructor.
public Student() { } }
}

二、DbContext数据库上下文

DbContext数据库上下文,定义了从实体对象到数据库的映射,从数据库中检索数据,就要使用它。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.Entity;
using EFCodeFirstModels;
using System.Configuration; namespace EFCodeFirstDataAccess
{
public class EFCodeFirstDbContext:DbContext
{ public EFCodeFirstDbContext():base("name=MyStrConn")
{
}
public DbSet<Student> Students { get; set; }
}
}

在使用DbContext时要先通过NuGet添加EntityFramework,在类中引入System.Data.Entity,像上面的代码中我们给DbContext指定了数据库连接字符串,名字是MyStrConn,我们可以看下DbContext类的构造函数.

上面提供了几种构造函数,今天主要看下第一个传nameOrConnectionString和无参数的。如果不传参数,它会自定将数据库的名字命名为类库名.类名,像上面的如果不使用无参数的构造函数会创建一个名为EFCodeFirstDataAccess.EFCodeFirstDbContext的数据库。而我们的demo中是使用了参数的,参数的名是nameorConnectionString,注意是or那意味着有两种情况,一种是name,一种是ConnectionString,在上面的参数是"name=XXX",这种是ConnectionString,既然是ConnectionString,那肯定有连接字符串,在哪呢?我开始是写在了EFCodeFirstDataAccess类库中,可以始终报错,报初始化的错误,正确的是写在控制台应用程序中的配置文件中,在配置文件App.config中添加结点。这里也要注意是要提供providerName,而且configSections必须是configuration的第一个结点,我刚才把connectionStrings添加到第一个也是提示错误。

  <connectionStrings>
<add name="MyStrConn" providerName="System.Data.SqlClient" connectionString="Data Source=.;Initial Catalog=CodeFirstDb;Integrated Security=True"/>
</connectionStrings>

我们也可以不使用ConnectionString,而是直接复制数据库名,它会先找配置文件对于的连接字符串,如果未找到,则以它自己命名。

三、简单操作

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using EFCodeFirstModels;
using EFCodeFirstDataAccess; namespace EFCodeFirstDemo
{
class Program
{
static void Main(string[] args)
{
//using能及时释放资源,例如数据库连接异常,可以即使将上下文释放
using (var db=new EFCodeFirstDbContext())
{
Student stu = new Student("", "cuiyanwei", );
db.Students.Add(stu);
db.SaveChanges();
string name= db.Students.Select(p => p.Name).FirstOrDefault().ToString() ;
Console.WriteLine(name); Student stu1 = db.Students.Where(p=>p.StuId=="").FirstOrDefault() ;
stu1.Name = "CYW";
db.SaveChanges(); name = db.Students.Select(p => p.Name).FirstOrDefault().ToString();
Console.WriteLine(name); }
Console.ReadLine(); }
}
}

在上面代码中,主要是先新增一个Student对象然后插入数据库,打印输出此时的name,然后通过数据库上下文找到StuId=0001的学生,将name更改为CYW,

保存到数据库再次打印数据name,从打印结果我们可以看到name最后是CYW,数据库中最后的结果也是CYW。通过Profiler也能查看到sql执行的过程。

EF实体框架之CodeFirst一的更多相关文章

  1. EF实体框架之CodeFirst四

    在EF实体框架之CodeFirst二中也提到数据库里面一般包括表.列.约束.主外键.级联操作.实体关系(E-R图).存储过程.视图.锁.事务.数据库结构更新等.前面几篇博客把表.存储过程.视图这些算是 ...

  2. EF实体框架之CodeFirst五

    上一博客学习了下基本的约定配置,留下几个遗漏的,这篇就是学习下遗漏一复杂类型. 一.什么是复杂类型? 书中说道:“复杂类型也可视作值类型(?)可以作为附加属性添加到其他类.复杂类型与实体类型的区别在于 ...

  3. EF实体框架之CodeFirst二

    在codefirst一中也说了Mapping是实体与数据库的纽带,model通过Mapping映射到数据库,我们可以从数据库的角度来分析?首先是映射到数据库,这个是必须的.数据库里面一般包括表.列.约 ...

  4. EF实体框架之CodeFirst七

    前面的6篇博客基本把Code First学习的差不多了,今天这篇学习下code first中的并发控制和事务,基本也快学完了,顶多就差数据迁移. 在数据库中也是有锁和事务的概念,在C#中也是存在,当然 ...

  5. EF实体框架之CodeFirst六

    上午的时候把复杂类型学习了一下,想着趁着周六日把Code First学习完,所以下午还是把Code First中的关系学习下.在数据库中最重要的恐怕就是E-R图了,E-R体现了表与表直接的关系.使用C ...

  6. EF实体框架之CodeFirst三

    前两篇博客学习了数据库映射和表映射,今天学习下数据库初始化.种子数据.EF执行sql以及执行存储过程这几个知识. 一.数据库初始化策略 数据库初始化有4种策略 策略一:数据库不存在时重新创建数据库 D ...

  7. EF实体框架之CodeFirst八

    前面七篇基本把Code First学习了一下,不过code first中会出现一个问题,就是数据迁移的问题. 一.数据准备 还是在前面的demo上修改,这次使用Province和City类. publ ...

  8. C#.Net EF实体框架入门视频教程

    当前位置: 主页 > 编程开发 > C_VC视频教程 > C#.Net EF实体框架入门视频教程 > kingstone金士顿手机内存卡16G仅65元 1.EF实体框架之增加查 ...

  9. EF实体框架处理实体之间关联关系与EF延迟机制(下)

    在数据库中,表与表之间可能存在多种联系,比如,一对多,多对多的关系.当我们使用逻辑外键在数据库建立两张表之间的关系的时候,我们使用EF实体框架 必然也会将这种关系映射到我们的实体关系中来.所以,在我们 ...

随机推荐

  1. jQuery基础知识准备

    一. 代码风格在jQuery程序中,不管是页面元素的选择.内置的功能函数,都是美元符号"$"来起始的.而这个"$"就是jQuery当中最重要且独有的对象:jQu ...

  2. Codeforces Round #370 - #379 (Div. 2)

    题意: 思路: Codeforces Round #370(Solved: 4 out of 5) A - Memory and Crow 题意:有一个序列,然后对每一个进行ai = bi - bi  ...

  3. [工作中的设计模式]组合模式compnent

    一.模式解析 将对象组合成树形结构以表示“部分整体”的层次结构.组合模式使得用户对单个对象和使用具有一致性. 组合模式的要点是: 1.对象整体以树形层次结构进行展示 2.树的根节点和子节点均可以添加删 ...

  4. 我的c++学习(10)this指针

    问题:当在对象的外部访问该对象的公有成员时,必须指明是哪一个对象.但是当我们用对象的成员函数来访问本对象的成员时,在成员函数中只要给出成员名就可以实现对该对象成员的访问.再进一步可用同一个类创建很多个 ...

  5. jquery点击元素之外触发事件

    $("#errorMsg_layer").bind("click",function(e){ if($(e.target).closest("#err ...

  6. 李洪强经典面试题145-Runloop

    李洪强经典面试题145-Runloop   Runloop 什么是 Runloop? 从字面上讲就是运行循环. 它内部就是do-while循环,在这个循环内部不断地处理各种任务. 一个线程对应一个Ru ...

  7. TweenMax参数说明

    TweenMax 建立在 TweenLite 和 TweenFilterLite 基础之上,因此,又揉合了这二者的功能,使得功能更加的齐备,但是如果说易用性,觉得还是 TweenLite 来得方便一些 ...

  8. Unity_Shader(1)

    Shader需要作用在Material中才能起作用. 例子1: (1)创建Shader 将shader替换为以下代码: Shader"MyDir/FirstShader" { Su ...

  9. 《实战Java虚拟机》,最简单的JVM入门书,京东活动,满200就减100了,该出手了

    #京东满200—100单# 图书放血大卖了 <实战Java虚拟机>http://item.jd.com/11670385.html 参加京东满200减 100的大促,就在6.1这一天,仅此 ...

  10. MongoDB的配置、启动、关闭

    MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系 ...