Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Possible to set column ordering in Entity Framework

Is there any possible configuration to set database column ordering in entity framework code first approach..?

All of my entity set should have some common fields for keeping recordinfo

public DateTime CreatedAt { get; set; }
public int CreatedBy { get; set; }
public DateTime ModifiedAt { get; set; }
public int ModifiedBy { get; set; }
public bool IsDeleted { get; set; }

I want to keep this fields at the end of the table. Is there any possible EF configuration that i can use to config this rather than keeping this fields at the end of my model class.

like image 849
Isha John Avatar asked Apr 06 '17 05:04

Isha John


People also ask

How do I change the default value for EF core?

In the DbContext OnModelCreating you add the default value. The 'bool' property 'Active' on entity type 'Foundation' is configured with a database-generated default. This default will always be used for inserts when the property has the value 'false', since this is the CLR default for the 'bool' type.

Does Entity Framework have annotation?

DataAnnotations is used to configure the classes which will highlight the most commonly needed configurations. DataAnnotations are also understood by a number of . NET applications, such as ASP.NET MVC which allows these applications to leverage the same annotations for client-side validations.

What is fluent API .NET core?

Entity Framework Fluent API is used to configure domain classes to override conventions. EF Fluent API is based on a Fluent API design pattern (a.k.a Fluent Interface) where the result is formulated by method chaining.


1 Answers

I'm assuming you are using Entity Framework 6 since column ordering is not yet supported in EF Core.

You can use either data attributes or the fluent API to set column order.

To use a Data Attribute to set column order, reference System.ComponentModel.DataAnnotations and use the ColumnAttribute. You can also set the column name with this attribute if you want it to differ from the property name.

[Column("CreatedAt", Order=0)]
public DateTime CreatedAt { get; set; }
[Column("CreatedBy", Order=1)]
public int CreatedBy { get; set; }

Note the Order parameter is zero-based.

See also: http://www.entityframeworktutorial.net/code-first/column-dataannotations-attribute-in-code-first.aspx

Alternatively, you can use the Fluent API in the OnModelCreating method in your DbContext class:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    //Configure Column
    modelBuilder.Entity<EntityClass>()
                .Property(p => p.CreatedAt)
                .HasColumnOrder(0);
}

See also: http://www.entityframeworktutorial.net/code-first/configure-property-mappings-using-fluent-api.aspx

This way is a bit more verbose but you can have a more bit control over what's happening.

like image 156
Steve Avatar answered Sep 22 '22 03:09

Steve