ASP.NET MVC’de Mevcut Veritabanından Code First İle Model Oluşturma

Son yıllarda sık kullanılan Code First ile modelleme, var olan bir veritabanını esas alarak tersine mühendislik yoluyla yapılabiliyor. Aslında bu seçenek, Entity Framework 6.1.1 ile gelen bir özellik. O yüzden ilk olarak buradan Entity Framework 6.1.1 sürümünü indirip kuruyoruz. Örneğin anlaşılabilir olması için veritabanını oldukça basit seçtim.

1Projemize sağ tıklayıp Add->New Item->ADO.NET Entity Data Model seçiyoruz. Modelimize bir isim verdikten sonra karşımıza aşağıdaki gibi bir seçenek çıkıyor. Burada Code First From Database seçeneğini işaretliyoruz.

2Daha sonra önceden oluşturulmuş veritabanımızı belirterek connectionString ve ayarlamaların yapılmasını sağlıyoruz.

3Oluşturulan Haber.cs, Kategori.cs ve HaberContext.cs modellerini görebiliriz.

[Table("Haber")]
    public partial class Haber
    {
        public int Id { get; set; }

        [Required]
        [StringLength(50)]
        public string HaberAd { get; set; }

        [Column(TypeName = "ntext")]
        public string HaberMetin { get; set; }

        public int? KategoriId { get; set; }

        public virtual Kategori Kategori { get; set; }
    }

[Table("Kategori")]
    public partial class Kategori
    {
        public Kategori()
        {
            Haber = new HashSet<Haber>();
        }

        public int Id { get; set; }

        [StringLength(50)]
        public string KategoriAd { get; set; }

        public virtual ICollection<Haber> Haber { get; set; }
    }

public partial class HaberContext : DbContext
    {
        public HaberContext()
            : base("name=HaberContext")
        {
        }

        public virtual DbSet<Haber> Haber { get; set; }
        public virtual DbSet<Kategori> Kategori { get; set; }
        public virtual DbSet<sysdiagrams> sysdiagrams { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Entity<Haber>()
                .Property(e => e.HaberAd)
                .IsUnicode(false);

            modelBuilder.Entity<Kategori>()
                .Property(e => e.KategoriAd)
                .IsUnicode(false);
        }
    }

Web.config içinde Context adının kullanıldığı bağlantı ayarı da aşağıdaki gibi otomatik olarak oluşturulmaktadır.

<connectionStrings><add name="HaberContext" connectionString="data source=nevra-nevra\sqlexpress;initial catalog=Haber;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework" providerName="System.Data.SqlClient" /></connectionStrings></configuration>

Yorum bırakın