16

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.

Isha John
  • 593
  • 2
  • 5
  • 16
  • What if I have for instance 3 levels of inheritance and still have complete control fo column ordering? Thx! – Gonzalo Méndez Sep 15 '17 at 19:21
  • If you are using ef core, check the following post https://stackoverflow.com/questions/51443459/how-to-sort-inheritance-columns-ordering-in-ef-core-2-1/57178076#57178076 – arslanaybars Jul 24 '19 at 08:07

2 Answers2

19

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.

Steve
  • 9,335
  • 10
  • 49
  • 81
  • Thanks Steve for the great replay. I have one more question let say if i set column order for few fields in my model then what will be the order of the remaining column(I mean the column without order number in the same model). – Isha John Apr 06 '17 at 06:15
  • @IshaJohn I believe they are put after your numbered columns in alphabetical order. I'm not sure what happens if you don't start at 0 however. – Steve Apr 06 '17 at 06:19
  • I can see in EF6 "Order" property on ForeignKeys dosen't apply. If i have a property of some other class referred in my class, foreign key column for that property will be appearing last. Does anyone have solution for this? – ManojAnavatti Sep 14 '18 at 11:11
0

Just use:

using System.ComponentModel.DataAnnotations.Schema;

Code:

[DisplayColumn("Name" , Order = 1)]
public int UserName { get; set; }

Notice: column order by default takes a big number so if you ordered only this column it will be first one in the table unless you ordered another column with a lower order number which is in this case : 0

wonea
  • 4,783
  • 17
  • 86
  • 139
Zaheer Ul Hassan
  • 771
  • 9
  • 24