在VS2015添加新建項時,選擇數據->ADO.NET 實體數據模型,有一下選項

來自數據庫的EF設計器,這個就是我們最常用的EntityFramework設計模型了,選擇它,然後根據設計好的數據庫,就會生成一個edmx文件,和一個數據庫上下文,然後我們就可以不用寫sql也可以愉快的訪問數據啦,但是這種方式對於經常變動的數據庫結構,更新起來經常會有一些bug,原數據庫刪除的字段和結構,在edmx中更新模型是需要手動刪除的
CodeFitst的出現給.net開發提供了一種新的方式,這種以代碼優先的數據庫模型更能適應需求的變更和產品迭代開發,接下來就以一個簡單的實例來看一下怎麼使用它吧
1.在自己的解決方案下添加一個類庫項目Domain,然後添加一個實體
public class User
{
public int Id { get; set; }
public int UserName { get; set; }
public string Password { get; set; }
}
2.添加數據庫上下文
public class DBContext:DbContext
{
public DBContext()
: base("Blog")
{
}
public DbSet<User> Users { get; set; }
}
3.配置數據庫連接字符串
需要注意的事,連接字符串需要寫到啟動項目中,如果當前啟動項目是Domain,那它就是以Domain的App.comfig為准,如果是web項目就是Web.config
一般情況下兩個都寫一下吧
<connectionStrings>
<add name="Blog" connectionString="server=.;database=Blog;uid=sa;pwd=123" providerName="System.Data.SqlClient"/>
</connectionStrings>
4.通常這個時候只需要運行你的程序,系統就會自動創建數據庫了,還有一種方法就是使用migration創建你的數據庫
打開程序包管理控制台,注意默認項目是Domain
PM> Enable-Migrations
你會發現Domain下多了一個Migrations文件夾,並且有一個名稱為Configuration的類(用於更新)
打開程序包管理控制台
PM> Add-Migration Init
這個時候,它會根據DBContext上下文下的模型來和以往的版本比較,並且生成更新文件,此時沒有以往版本,所以更新內容如下
namespace Domain.Migrations
{
using System;
using System.Data.Entity.Migrations;
public partial class Init : DbMigration
{
public override void Up()
{
CreateTable(
"dbo.Users",
c => new
{
Id = c.Int(nullable: false, identity: true),
UserName = c.Int(nullable: false),
Password = c.String(),
})
.PrimaryKey(t => t.Id);
}
public override void Down()
{
DropTable("dbo.Users");
}
}
}
Up用於更新,Down用於回退這個很好理解
PM> Update-database
打開Sql Server(如果用的localDb就在localDb中查看)查看數據庫
