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.
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.
这篇关于可以在实体框架中设置列排序的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:可以在实体框架中设置列排序


- 带有服务/守护程序应用程序的 Microsoft Graph CSharp SDK 和 OneDrive for Business - 配额方面返回 null 2022-01-01
- 如何用自己压缩一个 IEnumerable 2022-01-01
- Web Api 中的 Swagger .netcore 3.1,使用 swagger UI 设置日期时间格式 2022-01-01
- 输入按键事件处理程序 2022-01-01
- 良好实践:如何重用 .csproj 和 .sln 文件来为 CI 创建 2022-01-01
- C# 中多线程网络服务器的模式 2022-01-01
- WebMatrix WebSecurity PasswordSalt 2022-01-01
- C#MongoDB使用Builders查找派生对象 2022-09-04
- 在哪里可以找到使用中的C#/XML文档注释的好例子? 2022-01-01
- MoreLinq maxBy vs LINQ max + where 2022-01-01