想请问各位大神,EF如何创建索引。。。。

黑子大哥 2017-04-21 10:48:59
使用EF如何创建索引???
比如有一个字段

[Index]
public DateTime Updated{ get; set; }
[Index]
public DateTime Created { get; set; }

我不想在字段上加属性的方式创建,比如复合索引的情况下,多个字段无法满足,这样会有2个索引

第二种方案
在数据库迁移的时候写

public override void Up()
{
this.CreateIndex();
}

这种创建方式可以,但是有时候迁移迁移的,有的迁移类已经被我删除,时间久了我都忘记那些有索引,那些没有索引了,后期维护累人

在EntityTypeConfiguration的时候,我习惯在这里去配置实体的类型,但是这里面无法配置索引
比如写主键
 this.HasKey(a => a.ID);


还有别的方案吗?比如在执行迁移之前执行一段sql什么的?我可以将所有的索引都写在一个文件中


还请各位大神解答一下
...全文
1161 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
winner2050 2017-07-29
  • 打赏
  • 举报
回复
简单的索引可以通过Index特性添加。 sql2005以上支持的那种覆盖索引还得事后添加。
liubin911 2017-07-26
  • 打赏
  • 举报
回复
我都是在数据库里建的
lshfong 2017-07-23
  • 打赏
  • 举报
回复
最好在数据库里创建,从性能考虑不建议在EF里创建
asdcxzsx 2017-07-22
  • 打赏
  • 举报
回复
我也有类似的疑问,好像目前还没有适合的解决方案。我也想在Model类以属性那样的方式建立索引是最科学与方便的。希望Ef早日升级。code first方便大众
正怒月神 版主 2017-06-09
  • 打赏
  • 举报
回复
好像不行,只能在数据库创建。 最多你通过ef的sqlquery来写sql语句创建索引。
exception92 2017-06-09
  • 打赏
  • 举报
回复
我了个擦,原来是索引。
exception92 2017-06-09
  • 打赏
  • 举报
回复
在Mapping 里可以设置HasDatabaseGeneratedOption 呀,
黑子大哥 2017-06-09
  • 打赏
  • 举报
回复
来个人 接个贴
黑子大哥 2017-04-21
  • 打赏
  • 举报
回复
人呢 人呢????没有人吗?

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧