上篇博客中大概介绍了一下EF的三种类型。前两天刚刚实现了一个codefirst的demo,跟大家分享一下。
codefirst也叫codeonly,顾名思义代码先行。只写代码就行。在这儿我们不用管数据库设计成什么样,从需求分析开始,设计实体类实现我们所需的功能。这样更好的脱离了我们的面向数据库编程。
一,首先创建一个项目。(创建两个实体类,一个上下文类,一个主程序类。)
1.先写两个实体类的代码
customer实体类:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.ComponentModel.DataAnnotations; //新添加的引用为[key]
namespace CodeOnly
{
public class Customer
{
[Key]
public int Id { get; set; }
public string CusName { get; set; }
//因为一个顾客可以有多个订单,一对多的关系,所以这儿有个集合
public virtual ICollection<Order> Order { get; set; }
}
}
order实体类:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.ComponentModel.DataAnnotations; //新添加的引用为[key]
namespace CodeOnly
{
public class Order
{
[Key] //告诉数据库这是个主键
public int Id { get; set; }
public string Content { get; set; }
//定义外键
public int CustomerId { get; set; }
//导航属性
public Customer Customer { get; set; }
}
}
写之前首先弄清楚实体之间的关系。
2.实现上下文类代码(写之前添加一个EntityFramework的引用)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.Entity; //需要新添加的引用
namespace CodeOnly
{
//继承DbContext时需要引用Entity FrameWork。在 packages包里。
public class HotelDbContext:DbContext
{
public HotelDbContext()
: base("name=ConncodeFirst")
{
}
public DbSet<Customer> Customer { get; set; }
public DbSet<Order> Order { get; set; }
}
}
3.主程序代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace CodeOnly
{
class Program
{
static void Main(string[] args)
{
HotelDbContext dbContext = new HotelDbContext();
dbContext.Database.CreateIfNotExists(); //创建数据库,如果不存在。
}
}
}
二,编写配置文件
然后点击运行,打开数据库就会发现多出一个codeFirstDemo数据库。
codefirst是新增的一种方式,对于初学者来说写起来比较麻烦,但是我觉得既然增加了,肯定是趋势的潮流,我们有必要学习一下。刚刚接触,好处在慢慢的发现。