Entity Framework5 code first 学习1

       因为要学习Nopcommerce,就学习了EF5 CodeFirst。当初在Nopcommerce 1.9中是EF4,说实话对Linq to Entity 不大喜欢。如今却发现这个新技术有大行其道的趋势了。

拥抱变化吧。

      Code First其宗旨大概是不用先建立数据库,不用EF4里的edmx配置文件,通过编码就可以建立数据库,操纵数据库。传统的开发方法一般都要先建数据库。

      使用Code First,有两个有用的类:DBContext,DBSet。所属命名空间:System.Data.Entity。当然要引入一个EntityFramework.dll。

      必须先建立一个DBContext的子类,去连接建立数据库。

      DBSet 是一个实体的集合。

     假如有这么个案例宠物医院收治患畜的业务模型。

 1 public   class Patient
 2 {
 3 
 4         public Patient()
 5         {
 6 
 7             Visits = new List<Visit>();
 8 
 9         }
10         public int Id { get; set; }
11 
12         public string Name { get; set; }
13        
14         public DateTime BirthDate { get; set; }
15         public AnimalType AnimalType { get; set; }
16         public DateTime FirstVisit { get; set; }
17         public List<Visit> Visits { get; set; }
18
19     }

    定义这样一个实体,将要映射到数据库中,成为一个表。看看这个定义,有经验的人会问到:

主键是哪个字段?Name这个字段长度是多少?你猜对了,这个定义还少了一些东西,用于对实体进行限定。

限定实体有两种方式: DataAnnotations 和 Fluent API。前者简单,后者有点繁琐,但是后者可以做一些前者做不到的事情。

实体在使用DataAnnotations定义数据库和验证,要引入这两个namespace:

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

主要的DataAnnotationAttribute有这么几个:

[Key]

数据库: 定义主键

[Required]

数据库: 会把字段设置成not null

验证: 会要求必须输入

是否可以为null [Required(AllowEmptyStrings = false)] 不能为null和空字符串

[MaxLength] [MinLength]

[ForeignKey("列名")]

这个是定义外键的。

 

定义好实体之后,DBContext和dbset出场。

    public class VetContext : DbContext
    {
        public VetContext(string contstr):base(contstr)
        {
        }
        public DbSet<Patient> Patients { get; set; }
        public DbSet<Visit> Visits { get; set; }

    }

  注意VetContext的构造函数,参数是数据库连接串,好像SqlConnection哦,

  private static void CreateNewPatient()
        {
            var dog = new AnimalType { TypeName = "Dog" };
            var patient = new Patient

            {

                Name = "Sampson",
                BirthDate = new DateTime(2008, 1, 28),
                FirstVisit = new DateTime(2011,1,1),
                AnimalType = dog,
                Visits = new List<Visit>{
new Visit{Date = new DateTime(2011, 9, 1)}
}

            };

            using (var context = new VetContext("Data Source=localhost;Initial Catalog=EFTest;Integrated Security=False;Persist Security Info=False;User ID=sa;Password=aa;MultipleActiveResultSets=True"))
            {

                context.Patients.Add(patient);//将实体添加到集合中
                context.SaveChanges();//修改数据库

            }

        }
        static void Main(string[] args)
        {
            CreateNewPatient();
        }

  

例子附件

 

转载于:https://www.cnblogs.com/xinchuang/archive/2013/06/06/3120439.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值