- 实体框架教程
 - 实体框架 - 主页
 - 实体框架 - 概述
 - 实体框架 - 架构
 - 实体 F - 环境设置
 - 实体框架 - 数据库设置
 - 实体框架 - 数据模型
 - 实体框架-DbContext
 - 实体框架 - 类型
 - 实体框架 - 关系
 - 实体框架 - 生命周期
 - 实体 F - 代码优先方法
 - 实体 F - 模型优先方法
 - 实体 F - 数据库优先方法
 - 实体框架 - DEV 方法
 - 实体F——数据库操作
 - 实体框架 - 并发
 - 实体框架 - 事务
 - 实体框架 - 视图
 - 实体框架 - 索引
 - 实体 F - 存储过程
 - 实体 F - 断开连接的实体
 - 实体 F - 表值函数
 - 实体框架 - 本机 SQL
 - 实体框架 - 枚举支持
 - 实体F - 异步查询
 - 实体框架 - 持久性
 - 实体 F - 投影查询
 - 实体 F - 命令记录
 - 实体F——命令拦截
 - 实体框架 - 空间数据类型
 - 实体框架 - 继承
 - 实体框架 - 迁移
 - 实体框架 - 预加载
 - 实体框架 - 延迟加载
 - 实体框架 - 显式加载
 - 实体框架 - 验证
 - 实体框架 - 跟踪更改
 - 实体框架 - 彩色实体
 - 实体 F - 代码优先方法
 - 实体框架 - 第一个示例
 - 实体框架 - 数据注释
 - 实体框架 - 流畅的 API
 - 实体框架-种子数据库
 - 实体 F - 代码优先迁移
 - 实体 F - 多个 DbContext
 - 实体 F - 嵌套实体类型
 
- 实体框架资源
 - 实体框架 - 快速指南
 - 实体框架 - 有用的资源
 - 实体框架 - 讨论
 
实体框架 - 索引
索引是基于表和视图的磁盘数据结构。在大多数情况下,索引使数据检索更快、更高效。但是,使用索引超载表或视图可能会影响其他操作(例如插入或更新)的性能。
索引是实体框架中的新功能,您可以通过减少从数据库查询数据所需的时间来提高 Code First 应用程序的性能。
您可以使用“索引”属性向数据库添加索引,并覆盖默认的“唯一”和“聚集”设置以获得最适合您的场景的索引。
我们看一下下面的代码,其中在Course类中为CourseID添加了Index属性。
public partial class Course {
   public Course() {
      this.Enrollments = new HashSet<Enrollment>();
   }
   [Index]
   public int CourseID { get; set; }
   public string Title { get; set; }
	
   public int Credits { get; set; }
   public byte[] VersionNo { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}
上面创建的密钥是非唯一的、非聚集的。有重载可用于覆盖这些默认值 -
要使索引成为聚集索引,需要指定 IsClustered = true
同样,您也可以通过指定 IsUnique = true 使索引成为唯一索引
让我们看一下以下 C# 代码,其中索引是聚集的且唯一的。
public partial class Course {
   public Course() {
      this.Enrollments = new HashSet<Enrollment>();
   }
   [Index(IsClustered = true, IsUnique = true)]
   public int CourseID { get; set; }
   public string Title { get; set; }
	
   public int Credits { get; set; }
   public byte[] VersionNo { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}
索引属性可用于在数据库中创建唯一索引。但是,这并不意味着 EF 在处理关系等时能够推理出列的唯一性。此功能通常称为对“唯一约束”的支持。