使用Code Fisrt步骤

1、开启VS,创建控制台项目:CodeFirstDemo1


2、利用NuGet引进 Entity Framework类库


         图住:右击项目名称,在弹出的选项菜单选择【管理NuGet程序包(N)】
      
       图注:在选择或搜索EntityFramework,当前最新版本为6.3.1


       图注:添加成功后会多3个引用,和一个packages.config文件,App.config内容也发生了相应的变化
      
3、添加实体类文件(POCO)    Category.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace CodeFirstDemo1
{
class Category
{
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; } }
}

4、在配置文件中创建数据库连接字符串,<configuration>节点内加,其中Model1 需要在DbContext用到,用来关联数据库,CodeFirstSample为数据库名称(不需要在SQL Server Management Studio中先建数据库)

<connectionStrings>
          <add name="Model1" connectionString="data source=.;initial catalog=CodeFirstSample;persist security info=True;user id=sa;password=123456;MultipleActiveResultSets=True;App=EntityFramework" providerName="System.Data.SqlClient" />
     </connectionStrings>

5、添加上下文类CodeFirstContext继承DbContext(需引入命名空间 using System.Data.Entity;),名字随意,建议末尾加Context

using System;
using System.Collections.Generic;
using System.Data.Entity;//
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace CodeFirstDemo1
{
class CodeFirstContext : DbContext
{
public DbSet<Category> Categories { get; set; } public CodeFirstContext()
: base("name=Model1")//配置文件中的数据库连接字符串名称Model1
{ } protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
//在这里写映射到数据库表和字段的规则,不写为EF默认
}
}
}

6、访问(操作)实体类,编辑Program类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace CodeFirstDemo1
{
class Program
{
static void Main(string[] args)
{
using (var context = new CodeFirstContext())
{
//添加一个分类
var category = new Category { Name = "水果", Description = "水果分类的描述。" };
context.Categories.Add(category);
context.SaveChanges(); //
var q = from c in context.Categories
select c;
foreach (var item in q)
{
Console.WriteLine("{0} {1} {2}", item.Id, item.Name, item.Description);
}
Console.ReadKey();
}
}
}
}

7、试运行,结果
   


    图注:数据库和表,字段都生成成功,到这就完成了一次最小限度的完整的Code Fisrt示例。

后续问题

如上图的表字段,Name的类型长度是max,表的名称我不想叫Categories,如果我再加个子表如 Product,该如何用Code First实现呢?

这个时候就需要用到什么有备注的地方OnModelCreating  这个方法内写映射规则了。

简单Demo 使用Code Fisrt步骤的更多相关文章

  1. Spring的简单demo

    ---------------------------------------- 开发一个Spring的简单Demo,具体的步骤如下: 1.构造一个maven项目 2.在maven项目的pom.xml ...

  2. android JNI 简单demo(2)它JNI demo 写

    android JNI 简单demo(2)它JNI demo 写 一.搭建Cygwin 环境:http://blog.csdn.net/androidolblog/article/details/25 ...

  3. 服务网关Ocelot 入门Demo系列(01-Ocelot极简单Demo及负载均衡的配置)

    [前言] Ocelot是一个用.NET Core实现并且开源的API网关,它功能强大,包括了:路由.请求聚合.服务发现.认证.鉴权.限流熔断.并内置了负载均衡器与Service Fabric.Butt ...

  4. 20个令人惊叹的深度学习应用(Demo+Paper+Code)

    20个令人惊叹的深度学习应用(Demo+Paper+Code) 从计算机视觉到自然语言处理,在过去的几年里,深度学习技术被应用到了数以百计的实际问题中.诸多案例也已经证明,深度学习能让工作比之前做得更 ...

  5. Django实战(一)之简单Demo

    菜鸟教程上Django安装可供参考: 参考链接: http://www.runoob.com/django/django-install.html 菜鸟教程上如果不行的话,下面博客网址可以供参考 Li ...

  6. Spring环境搭建及简单demo

    1. Spring框架简介(以下这段话可用于面试求职) Spring为JavaEE开发提供了一个轻量级的解决方案,主要表现为, IOC(或者叫做DI)的核心机制,提供了bean工厂(Spring容器) ...

  7. 设计模式之单例模式的简单demo

    /* * 设计模式之单例模式的简单demo */ class Single { /* * 创建一个本类对象. * 和get/set方法思想一样,类不能直接调用对象 * 所以用private限制权限 * ...

  8. 使用Spring缓存的简单Demo

    使用Spring缓存的简单Demo 1. 首先创建Maven工程,在Pom中配置 <dependency> <groupId>org.springframework</g ...

  9. Managed DirectX中的DirectShow应用(简单Demo及源码)

    阅读目录 介绍 准备工作 环境搭建 简单Demo 显示效果 其他 Demo下载 介绍 DirectX是Microsoft开发的基于Windows平台的一组API,它是为高速的实时动画渲染.交互式音乐和 ...

随机推荐

  1. vue.js入门学习

    可以用淘宝npm镜像 然后安装 然后初始化项目: Watch就是一个监听 v-if是如果为false就根本不在页面存在这个元素 v-show是通过display:none来控制这个元素的显示和隐藏 r ...

  2. D3_book 11.2 stack

    <!-- book :interactive data visualization for the web 11.2 stack 一个堆叠图的例子 --> <!DOCTYPE htm ...

  3. js-实现搜狐列表

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...

  4. ASP.NET Web API 框架研究 ASP.NET 路由

    ASP.NET Web API 如果采用Web Host方式来寄宿,在请求进入Web API 消息处理管道之前,就会用ASP.NET 自身的路由系统根据注册的路由表,解析出当前请求的HttpContr ...

  5. wordpress和数据库的连接

    1.首先在数据库里创建wordpress数据库 2.在网页上配置WordPress,安装WordPress 如上配置不对,提交时提示了错误,于是我选择了root用户 123456, 3.提交后,连上了 ...

  6. Opencv打开摄像头,读不到图像,一般来说先读取第一帧,舍弃,然后就正常了

    舍弃第一帧的程序: cap >> img; cv::waitKey(100);  if (cvWaitKey(5) == 27) break; cap >> img;

  7. Android-Java构造代码块&构造方法隐式三行

    构造代码块: 描述Teacher对象/实体: package android.java.oop06; public class Teacher { private int id = 007; priv ...

  8. hdu 1.2.6

    勾股定理... #include<cstdio> #include<algorithm> using namespace std; int main() { //freopen ...

  9. Win7的“以管理员身份运行”

    如果HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System\EnableLUA被设置为0,则"以管理员身份运行" ...

  10. ASP.NET MVC的切片(Section)脚本(script)

    在ASP.NET MVC使用切片脚本,实在是很溜. 在使用layout之后,只是视图套用_Layout之后,在视图中任一位置任一时候均可以使用切片脚本. 首先在_Layout.cshtml定一些规则: ...