zoukankan      html  css  js  c++  java
  • Lerning Entity Framework 6 ------ Defining the Database Structure


    There are three ways to define the database structure by Entity Framework API. They are:

    • Attributes
    • The DbModelBuilder API
    • Configuration Classes

    Attributes

    We can Add some attributes for entities or proteries to configure database structures. For example. Add some codes:

    [Table("People")]
    public class Person
    {
        [Key]
        public int PersonId { get; set; }
    
        [Required]
        [MaxLength(50)]
        public string Name { get; set; }
    
        [MaxLength(200)]
        public string Address { get; set; }
    }
    
    public class MyDb : DbContext
    {
        public MyDb():base("name=Test")
        {
    
        }
    
        public DbSet<Person> People { get; set; }
    }
    

    These attributes are in the namespace System.ComponentModel.DataAnnotations and System.ComponentModel.DataAnnotations.Schema.

    Then, execute the command Update-Database in Nuget command line. Now, look over the database:

    图片.png-4kB

    If you don't set any limit,the Entity Framework will also create the table successful, but maybe there are something you don't want. For example, if you remove the attribute MaxLength, the column's type will be longtext(I'm using MySql). You should take some attention to it.

    The DbModelBuilder API

    We also can use DbModelBuilder API to do it:

    public class MyDb : DbContext
    {
        public MyDb():base("name=Test")
        {
    
        }
    
        public DbSet<Person> People { get; set; }
    
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
    
            modelBuilder.Entity<Person>().ToTable("People");
    
            modelBuilder.Entity<Person>().Property(p => p.Name)
                .HasMaxLength(50)
                .IsRequired();
    
            modelBuilder.Entity<Person>().Property(p => p.Address)
                .HasMaxLength(200);
        }
    }
    

    Delete the table people first, then, execute the command Update-Database in Nuget command line and look over the database.

    Configuration Classes

    If we have too many entities, the class DbContext will contains too much codes. There is another way to define the database structure. You can Create a configuation class for each entities:

    public class PersonMap : EntityTypeConfiguration<Person>
    {
        public PersonMap()
        {
            ToTable("People");
            Property(p => p.Name).HasMaxLength(50).IsRequired();
            Property(p => p.Address).HasMaxLength(200);
        }
    }
    

    The namespace is System.Data.Entity.ModelConfiguration. Then, make DbContext some codes:

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
    
        modelBuilder.Configurations.Add(new PersonMap());
    }
    

    Delete the table people first, then, execute the command Update-Database in Nuget command line and look over the database.

    That's all.

  • 相关阅读:
    Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示
    总结软连接和硬连接区别,并用实例操作说明
    描述文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息?
    Git Shell push_code 脚本
    YDD的铁皮锅——C/C++内存概念
    Linux Shell 常见用法及问题
    MFC 设置鼠标样式(SetSystemCursor函数问题)
    Qt QTableView自定义列表(插入图片)
    Github libinjection库研究总结
    Windows/Linux:VMware虚拟机用内网IP通讯
  • 原文地址:https://www.cnblogs.com/zzy0471/p/6828956.html
Copyright © 2011-2022 走看看