Entity Framework CodeFirst------使用CodeFirst方式建立数据库连接(一)
本文分步演练介绍通过 Code First 开发建立新数据库。这个方案包括建立不存在的数据库(Code First 创建)或者空数据库(Code First 向它添加新表)。借助 Code First,可以使用 C# 类定义模型。可以选择使用类的特性和属性执行其他配置,也可以使用 Fluent API 执行其他配置。
1.使用工具
Vs2010、Vs2012或者Vs2013,本文使用的IDE是Vs2013
Nuget程序管理包
2.创建应用程序
简单起见,我们将使用visual studio创建一个控制台应用程序,将控制台命名为EntitySample,创建完成后,我们在项目下面新建一个文件夹并命名为Model,新建一个Student类,在student类中添加几个属性
public Class Student
{
public int ID{ get; set; } public string Name { get; set; } public string Class { get; set; } public int Age { get; set; }
}
3.创建实体DbContext
DbContext称之为数据库上下文,其可以代表一个数据库的集合或者表示为数据库的一个会话,以便我们查询和保存数据。我们定义一个派生自 System.Data.Entity.DbContext 的上下文,并为模型中的每个类公开一个类型化 DbSet<TEntity>,通过该上下文可以使用linq进行查询工作。在使用DbContext之前,我们需要添加 EntityFramework NuGet 程序包。
项目”–>“管理 NuGet 程序包…”
注意:如果没有“管理 NuGet 程序包…”选项,则应安装 最新版本的Nuget
选择“联机”选项卡
输入EntityFramework 查找 选择“EntityFramework”程序包
单击“安装”
安装完成后。我们在项目下新建一个文件夹DbClassContext,在该文件夹下添加一个类 并命名为EntityClassContext,添加 System.Data.Entity 引用,并将类继承自DbContext。
该类主要管理我们自定义的所有的实体类。通过DbSet设置 DbSet代表数据库中的所有实体
public Class EntityClassContext: DbContext
{
public DbSet<Student> StudentContext { get; set; }
}
4.在Program.cs控制台程序main方法中写入代码

5.运行效果如下

6.这样我们通过EntityFramework创建了一个数据库,这个时候我们就会有一个疑问,我们都没有配置数据库连接,打开项目的app.config,我们发现并没有配置数据库的连接字符串,那么数据到底存储在哪儿去了。
原来我们在安装完成VS2010、12、13时,其会安装一个SQL Express实例,如果SQL Express 不可用则 Code First 将尝试使用 LocalDb(默认情况下随 Visual Studio 2012 安装)数据库以项目名称+派生上下文的完全限定名命名,在我们的示例中上下文是EntitySample.EntityClassContext,所以我们会生成上述名称的数据库。
7.可以在 Visual Studio 中使用服务器资源管理器连接至此数据库
“视图”->“服务器资源管理器”
右键单击“数据连接”并选择“添加连接…”
如果尚未从服务器资源管理器连接至数据库,则需要选择 Microsoft SQL Server 作为数据源连接至 LocalDb ((localdb)\v11.0) 或 SQL Express (.\SQLEXPRESS),具体取决于安装情况


8.连接成功后,我们可以查看到我们刚才添加的数据。
9.如果我们是在正式的开发过程中,可能需要连接本地的sql或者远程的sql,那么我们需要更改数据库连接方式。如果需要更改的话,我们打开项目下面的app.config配置文件,在<configuration></configuration>标签下面配置连接字符串。name是指我们派生的DbContext名称


10.通过配置上述字符串后,我们可以连接自己需要的数据库,如果你需要连接其他数据库,可以更改数据库连接字符串。因为此次的实例项目比较简单,园友们可以自己创建项目实验即可。
下节我们集中讨论一下Entity Framework在数据结构变化的时候,如何处理。
Entity Framework CodeFirst------使用CodeFirst方式建立数据库连接(一)的更多相关文章
- Oracle中使用Entity Framework 6.x Code-First
Oracle中使用Entity Framework 6.x Code-First方式开发 去年写过一篇EF的简单学习笔记,当时EF还不支持Oracle的Code-First开发模式,今天无意又看了下O ...
- Entity Framework入门教程: Entity Framework支持的查询方式
Entity Framework支持的查询方式有三种 LINQ to Entities Entity SQL Native SQL [LINQ to Entities] LINQ(语言集成查询)是从V ...
- Entity Framework常用的查询方式
Entity Framework支持的查询方式有三种 LINQ to Entities Entity SQL Native SQL [LINQ to Entities] LINQ(语言集成查询)是从V ...
- Oracle中使用Entity Framework 6.x Code-First方式开发
去年写过一篇EF的简单学习笔记,当时EF还不支持Oracle的Code-First开发模式,今天无意又看了下Oracle官网,发现EF6.X已经支持了,并且给出了二篇教程(英文版): 1.Using ...
- 如何使用ASP.NET Web API OData在Oracle中使用Entity Framework 6.x Code-First方式开发 OData V4 Service
环境: Visual Studio 2013 + .Net Framework 4.5.2 1.新建项目 2.安装OData,ODP.NET 安装的包: 下面是部分代码: using System; ...
- Entity Framework 自动生成CodeFirst代码
前言 在前面的文章中我们提到Entity Framework的“Code First”模式也同样可以基于现有数据库进行开发.今天就让我们一起看一下使用Entity Framework Power To ...
- [EF] 如何在 Entity Framework 中以手动方式设定 Code First 的 Migration 作业
Entity Framework (简称 EF) 发展到现在, 版本已经进入 6.1.0, 距离我写的「在 VS2013 以 Code First 方式建立 EF 资料库」这篇文章已有半年的时间.如果 ...
- Entity Framework之DB First方式
EF(Entity Framework的简称,下同)有三种方式,分别是:DataBase First. Model First和Code First. 下面是Db First的方式: 1. 数据库库中 ...
- Entity Framework后台采用分页方式取数据与AspNetPager控件的使用
本文是一个对AspNetPager控件使用的笔记! 有关AspNetPager控件可以查看杨涛主页.这是一个开放的自定义ASP.NET控件,支持各种自定义的数据分页方式,使用很方便,而且功能也很强大, ...
随机推荐
- AngularJS测试框架 karma备忘
AngularJS测试框架karma安装 安装karma $ --save-dev 安装karma组件 $ npm install karma-jasmine karma-chrome-launche ...
- 编程思想—控制反转(IOC)及依赖注入(DI)
1.什么是依赖注入 在面向对象的编程语言中,一个对象的行为方法往往需要外界的对象的行为协助才能完成. 例如:小李去ATM机取钱,那小李的取钱的整个行为的完成需要ATM实例取款行为的协助才能完成. pu ...
- js performance
http://hqman.me/2012/js-module.html http://www.cnblogs.com/snandy/archive/2012/06/06/2536969.html ht ...
- JVM相关参数配置和问题诊断<转>
原文连接:http://blog.csdn.net/chjttony/article/details/6240457 1.Websphere JVM相关问题诊断: 由JVM引起的Websphere问题 ...
- input text的outline属性
普通的text选中编辑时会出现蓝色的边框,感觉不太美观,怎么去掉呢? 可以在text对应的样式里加入:outline: 0;
- DestroyWindow
假设自己通过new创建了一个窗口对象pWnd,然后pWnd->Create.则销毁窗口的调用次序: 1. 手工调用pWnd->DestroyWindow(): 2. ...
- c# 函数练习;结构体、枚举类型
* 结构体 1.就是一个自定义的集合,里面可以放各种类型的元素,用法大体跟集合一样. 注意:枚举类型和结构体都属于值类型. 2.定义的方法: struct student { public in ...
- linux查看端口号是否被占用
etstat -anp |grep 端口号 root用户执行 netstat -ntupl n表示不查询dns t表示tcp协议 u表示udp协议 p表示查询占用的程序 l表示查询正在监听的程序 查看 ...
- 【转】Android ProgressDialog的使用2
原文网址:http://www.cnblogs.com/hnrainll/archive/2012/03/28/2420908.html <?xml version="1.0" ...
- NGU-学习笔记(1)-动态添加删除图集
现在 正在做unity的方向 不得不说我选的是UI方向 Unity中很有名的就是NGUI插件了.今天做了个ngui的简单背包系统.非常简陋..初学着 自己mark下 (1)预览 主要就是个 simpl ...