EF コード ファースト モデルは、データベースの構造を完全に記述することを目的としていますか?
いいえ、データベースの構造やスキーマを完全には記述していません。それでも、EF を使用してデータベースを完全に記述する方法があります。それらは以下のとおりです。
Database クラスで新しい CTP5 のExecuteSqlCommandメソッドを使用すると、生の SQL コマンドをデータベースに対して実行できます。
SqlCommandこの目的でメソッドを呼び出すのに最適な場所は、カスタムクラスでオーバーライドさSeedれたメソッド内です。例えば:Initializer
protected override void Seed(EntityMappingContext context)
{
    context.Database.ExecuteSqlCommand("CREATE INDEX IX_NAME ON ...");
}
この方法で一意の制約を追加することもできます。これは回避策ではありませんが、データベースが生成されるときに適用されます。
また
あなたが属性をひどく必要としているなら、ここに行きます
[AttributeUsage(AttributeTargets.Property, Inherited = false, AllowMultiple = true)]
public class IndexAttribute : Attribute
{
    public IndexAttribute(string name, bool unique = false)
    {
        this.Name = name;
        this.IsUnique = unique;
    }
    public string Name { get; private set; }
    public bool IsUnique { get; private set; }
}
OnModelCreatingこの後、以下のようにメソッドで呼び出すイニシャライザがあります。
public class IndexInitializer<T> : IDatabaseInitializer<T> where T : DbContext
{
    private const string CreateIndexQueryTemplate = "CREATE {unique} INDEX {indexName} ON {tableName} ({columnName});";
    public void InitializeDatabase(T context)
    {
        const BindingFlags PublicInstance = BindingFlags.Public | BindingFlags.Instance;
        Dictionary<IndexAttribute, List<string>> indexes = new Dictionary<IndexAttribute, List<string>>();
        string query = string.Empty;
        foreach (var dataSetProperty in typeof(T).GetProperties(PublicInstance).Where(p => p.PropertyType.Name == typeof(DbSet<>).Name))
        {
            var entityType = dataSetProperty.PropertyType.GetGenericArguments().Single();
            TableAttribute[] tableAttributes = (TableAttribute[])entityType.GetCustomAttributes(typeof(TableAttribute), false);
            indexes.Clear();
            string tableName = tableAttributes.Length != 0 ? tableAttributes[0].Name : dataSetProperty.Name;
            foreach (PropertyInfo property in entityType.GetProperties(PublicInstance))
            {
                IndexAttribute[] indexAttributes = (IndexAttribute[])property.GetCustomAttributes(typeof(IndexAttribute), false);
                NotMappedAttribute[] notMappedAttributes = (NotMappedAttribute[])property.GetCustomAttributes(typeof(NotMappedAttribute), false);
                if (indexAttributes.Length > 0 && notMappedAttributes.Length == 0)
                {
                    ColumnAttribute[] columnAttributes = (ColumnAttribute[])property.GetCustomAttributes(typeof(ColumnAttribute), false);
                    foreach (IndexAttribute indexAttribute in indexAttributes)
                    {
                        if (!indexes.ContainsKey(indexAttribute))
                        {
                            indexes.Add(indexAttribute, new List<string>());
                        }
                        if (property.PropertyType.IsValueType || property.PropertyType == typeof(string))
                        {
                            string columnName = columnAttributes.Length != 0 ? columnAttributes[0].Name : property.Name;
                            indexes[indexAttribute].Add(columnName);
                        }
                        else
                        {
                            indexes[indexAttribute].Add(property.PropertyType.Name + "_" + GetKeyName(property.PropertyType));
                        }
                    }
                }
            }
            foreach (IndexAttribute indexAttribute in indexes.Keys)
            {
                query += CreateIndexQueryTemplate.Replace("{indexName}", indexAttribute.Name)
                .Replace("{tableName}", tableName)
                .Replace("{columnName}", string.Join(", ", indexes[indexAttribute].ToArray()))
                .Replace("{unique}", indexAttribute.IsUnique ? "UNIQUE" : string.Empty);
            }
        }
        if (context.Database.CreateIfNotExists())
        {
            context.Database.ExecuteSqlCommand(query);
        }
    }
    private string GetKeyName(Type type)
    {
        PropertyInfo[] propertyInfos = type.GetProperties(BindingFlags.FlattenHierarchy | BindingFlags.Instance | BindingFlags.Public);
        foreach (PropertyInfo propertyInfo in propertyInfos)
        {
            if (propertyInfo.GetCustomAttribute(typeof(KeyAttribute), true) != null)
            return propertyInfo.Name;
        }
        throw new Exception("No property was found with the attribute Key");
    }
}
次にOnModelCreating、DbContext でオーバーロードします
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    Database.SetInitializer(new IndexInitializer<MyContext>());
    base.OnModelCreating(modelBuilder);
}
index 属性をエンティティ タイプに適用します。このソリューションを使用すると、同じ名前と一意の名前を使用するだけで、同じインデックスに複数のフィールドを含めることができます。
また
移行は後で行うことができます。
注:
このコードの多くはhereから取得しました。