最近面试时很多面试官都问到了EF框架 好记性不如烂笔头

赶紧记下来

code-first是EF框架中的一种,是使用实体类来进行数据库表的映射,所以实体类中的字段要规范(我认为) 比如:

如果有外键的话 一定要搞清楚一对多、多对一和多对多的关系

比如一个用户对应一个用户详细信息可以写成这样:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace QQManager.Models
{
    public class User
    {
        public Guid Id { get; set; }

        public string Name { get; set; }

        public virtual UserInfo UserInfo { get; set; }
    }
}

用户详细信息表:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace QQManager.Models
{
    public class User
    {
        public Guid Id { get; set; }

        public string Name { get; set; }

        public virtual UserInfo UserInfo { get; set; }
    }
}

如果是一对多要搞清楚他们之间的关系(谁包含谁),比如一个订单中包含多个商品

订单表:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace QQManager.Models
{
    public class Orders
    {
        public Guid Id { get; set; }

        public virtual List<Gooder> Gooder { get; set; }
    }
}

商品表:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace QQManager.Models
{
    public class Gooder
    {

        public Guid Id { get; set; }
        //商品名称
        public int Name { get; set; }
        //商品价格
        public int Price { get; set; }

        public virtual Orders Orders { get; set; }
    }
}

数据上下文:

using System;
using System.Collections.Generic;

// DbContext
using System.Data.Entity;

namespace QQManager.Models
{
    /// <summary>
    /// 数据库上下文
    /// </summary>
    public class QQContext:DbContext
    {
        public QQContext() : base("name=qq")//web.config中连接字符串的名称
        {
            //  当 模型发生变化时 重新创建数据库。
            Database.SetInitializer(new DropCreateDatabaseIfModelChanges<QQContext>());

        }
        //数据表,只要是模型类就要写进来
        public virtual DbSet<Order> Orders { get; set; }
    }
}

对于这种外键关系的字段,使用virtual关键字修饰用来懒加载,我在这里是只修饰了外键,其他字段也可以修饰,不碍事

具体的关于操作数据库的语法转载:https://blog.csdn.net/u013924731/article/details/53331610

这样在mvc架构中就可以使用code-first了,主要是其他架构我没使用过.....

顺便一提的是这样写唯一的麻烦就是在使用时每次都要实例化上下文,解决(不使用也不碍事):

using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Remoting.Messaging;
using System.Web;
using System.Web.Mvc;
using QQManager.Models;

namespace QQManager.Controllers
{
    public class BaseController : Controller
    {

        protected QQContext db
        {
            get
            {
                // 从当前线程中获取上下文数据。
                QQContext _db = CallContext.GetData("qq") as QQContext;
                if (_db == null)
                {
                    _db = new QQContext();
                    _db.Database.CreateIfNotExists();
                }
                // 将上下文数据保存到当前线程中。
                CallContext.SetData("qq",_db);
                return _db;
            }
        }
    }
}

这样只要继承此类就可以直接使用上下文,名称为自定义,这里是db。

Ef-Code-First 使用实体类映射出数据库的更多相关文章

  1. EF Code First:实体映射,数据迁移,重构(1)

    一.前言 经过EF的<第一篇>,我们已经把数据访问层基本搭建起来了,但并没有涉及实体关系.实体关系对于一个数据库系统来说至关重要,而且EF的各个实体之间的联系,实体之间的协作,联合查询等也 ...

  2. EF Code First:实体映射,数据迁移,重构

    经过EF的<第一篇>,我们已经把数据访问层基本搭建起来了,但并没有涉及实体关系.实体关系对于一个数据库系统来说至关重要,而且EF的各个实体之间的联系,实体之间的协作,联合查询等也都依赖于这 ...

  3. EF Code First:实体映射

    二.实体映射 实体与数据库的映射可以通过DataAnnotation与FluentAPI两种方式来进行映射: (一) DataAnnotation DataAnnotation 特性由.NET 3.5 ...

  4. Entity Framework(EF) Code First将实体中的string属性映射成text类型的几种方式

    1.通过ColumnType属性设置 [Column(TypeName="text")] public string Text { get; set; } 在进行以上属性设置时,请 ...

  5. 【繁星Code】如何在EF将实体注释写入数据库中

    最近在项目中需要把各个字段的释义写到数据库中,该项目已经上线很长时间了,数据库中的字段没有上千也有上百个,要是一个项目一个项目打开然后再去找对应字段查看什么意思,估计要到明年过年了.由于项目中使用En ...

  6. ASP.NET Core 中使用EF Core 将实体映射到数据库表的方法(SQL Server)

    前段时间听过一个关于使用ASP.NET Core建立项目的视频.其中使用EF Core映射到数据库的部分是按部就班地学习.今天自己建立项目时,有些步骤已经有一些遗忘.所以写下这篇文章,顺便理清思路. ...

  7. EF Code First连接现有数据库

    作为一个初入学习.net MVC4 的新手,想写一写今天碰到的问题,做一个总结. 首先我想利用EF Code First来连接我现有数据库,而不是通过EF Code First来自动生成数据库和表. ...

  8. 步步学LINQ to SQL:将类映射到数据库表【转】

    [IT168 专稿]该系列教程描述了如何采用手动的方式映射你的对象类到数据表(而不是使用象SqlMetal这样的自动化工具)以便能够支持数据表之间的M:M关系和使用实体类的数据绑定.即使你选择使用了自 ...

  9. 【极力分享】[C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例【转载自https://segmentfault.com/a/1190000004152660】

      [C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例 本文我们来学习一下在Entity Framework中使用Cont ...

随机推荐

  1. Spring相关知识点

    1.注解@qualifier 只能注在属性上 作用:当一个接口有多个实现类时,用Autowired装配时,因为Autowired是按类型装配的(Resource按名称),所以多个实现类会出现冲突,这是 ...

  2. msgs no .h file

    1.单独编译包,catkin_make --pkg 包名,failed,则 2.进入build下对应的msgs包中,使用make,以及make install,failed,则 3.使用catkin_ ...

  3. navicat下创建和执行存储过程

  4. 20155312张竞予 20170510实践一:在IDEA中以TDD的方式对String类和Arrays类进行学习

    实践题目 在IDEA中以TDD的方式对String类和Arrays类进行学习 测试相关方法的正常,错误和边界情况 String类 charAt split Arrays类 sort binarySea ...

  5. Java的GUI设计中如何跨界面传值

    在Java设计中我们会遇到登录界面的信息,在后面的某个情况也需要使用. 比如这是笔者的一个登录界面 可以看到获取密码和账号 在这个时候的功能的完成需要密码和账号 // 登录信息的获取 public S ...

  6. floor函数

    C++中 可以用floor函数来截断小数部分 floor(x)返回一个不大于x的整数,有点像取整函数

  7. mysql 外键理解

    假定一个班级的学生个人信息表: 什么是外键 在设计的时候,就给表1加入一个外键,这个外键就是表2中的学号字段,那么这样表1就是主表,表2就是子表.(注意: 外键不一定须要作为从表的主键.外键也不一定是 ...

  8. Lyft Level 5 Challenge 2018 - Final Round (Open Div. 2) C. The Tower is Going Home(思维+双指针)

    https://codeforces.com/contest/1075/problem/C 题意 一个宽为1e9*1e9的矩阵中的左下角,放置一个车(车可以移动到同一行或同一列),放置一些墙,竖的占据 ...

  9. flask 知识积累

    PythonWEB框架之Flask Flask快速入门,知识整理 Flask 框架

  10. java常用设计模式九:桥接模式

    一.概述 将抽象部分与它的实现部分分离,使它们都可以独立地变化.它是一种对象结构型模式.比如存在2个维度,第一个维度有一个抽象类A和对应的子类A1和A2:第二个维度有另一个接口B和对应的子类B1和B2 ...