MVC5学习小记(3)--数据库操作

来源:互联网 发布:我的世界,java.net 编辑:程序博客网 时间:2024/06/05 15:36

首先MVC怎么对数据库进行操作的呢,这里用到了微软的神器,EF6

EF4.1有三种方式来进行数据操作及持久化。分别是Database-First,Model-First,Code-first:


       1.Database First是基于已存在的数据库,利用某些工具(如Vs提供的EF设计器)创建实体类,数据库对象与实体类的匹配关系等,你也可以手动修改这些自动生成的代码及匹配文件。
       2 .Model First 这种方式是先利用某些工具(如VS的EF设计器)设计出实体数据模型及他们之间的关系,然后再根据这些实体、关系去生成数据库对象及相关代码文件。
      3.Code First 这种方式需要先写一些代码,如实体对象,数据关系等,然后根据已有的代码描述,自动创建数据对象,这种方式在前一篇文章已经简单说过了。但其实这种方法与Model First是非常类似的。我们自己写的代码,其实就是用代码表示实体模型,而Model First是用可视化的方式描述了实体模型。


我这里用Code first:

分别引用Mysql+EF。然后设置model

using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.ComponentModel.DataAnnotations;namespace test1.Models{    public class User    {                public String Id { get;set;}        [Required]        public String Name{get;set;}        [Required]        public String PassWord { get; set; }        [Required]        public int rolt { get; set; }    }}
model上下文:

using System;using System.Collections.Generic;using System.Data.Entity;using System.Linq;using System.Web;namespace test1.Models{    public class UserContext : DbContext    {        public UserContext() : base("name=UserContext")        {        }        public System.Data.Entity.DbSet<test1.Models.User> Users { get; set; }        }}

web.config操作

<connectionStrings>    <add name="UserContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=mvcweb;user id=root;password=root;" 
providerName="MySql.Data.MySqlClient"/>  </connectionStrings>
添加控制器


然后,运行,果断不行,因为这里没有创建数据库,也没有初始化,并且我初始化还出现各种问题,百度无果后,直接迁移。

 1.Enable-Migrations

 2.add-migration Initial

 3.Update-Database

然后数据库就有表了。可能在上步会出现问题。

参考 http://blog.csdn.net/tangolivesky/article/details/46507723