欢迎投稿

今日深度:

MongoDB学习笔记(六) MongoDB索引用法和效率分析(1(2)

二、维护索引

1. 查询索引

通过索引名查询的方式已有介绍。但有时候,我们可能忘记了索引名,怎么查询呢?

下面提供一个遍历全部索引的方法,打印全部索引信息:

  1. foreach (var index in mongoCollection.Metadata.Indexes)    
  2.  {    
  3.      Console.WriteLine(index.Value);    
  4.  }  

输出结果示例:

  1. "name""_id_""ns""myDatabase.UserInfo""key": { "_id"1 } }    
  2. "name""_UserId_unique_""ns""myDatabase.UserInfo""key": { "UserId"1 }, "unique"true"_id""4d8f406ab8a4730b78000005" }    
  3. "name""_UserName_""ns""myDatabase.UserInfo""key": { "UserName"1 }, "unique"false"_id""4d8f406ab8a4730b78000006" }    
  4. "name""_Detail.Address_Detail.Age_""ns""myDatabase.UserInfo""key": { "Detail.Address"1"Detail.Age": -1 }, "unique"false"_id""4d8f406ab8a4730b78000007" }    
  5. "name""_UserId_UserName_""ns""myDatabase.UserInfo""key": { "UserId"1"UserName": -1 }, "unique"false"_id""4d8f406ab8a4730b78000008" }    
  6. "name""_Detail_""ns""myDatabase.UserInfo""key": { "Detail"1 }, "unique"false"_id""4d8f406ab8a4730b78000009" }  

可见,集合的索引也是通过一个集合来维护的。name表示索引名,ns表示索引属于哪个库哪个集合,key表示索引在哪个键上,正序还是逆序,unique表示是否为唯一索引,等等...

2. 删除索引

新手常陷入的误区是,认为集合被删除,索引就不存在了。关系型数据库中,表被删除了,索引也不会存在。在MongoDB中不存在删除集合的说法,就算集合数据清空,索引都是还在的,要移除索引还需要手工删除。

例如,删除名为“_UserName_”的索引:

  1. mongoCollection.Metadata.DropIndex("_UserName_");  

下面提供删除除默认索引外其他全部索引的方法:

  1. public void DropAllIndex()    
  2. {    
  3.     var listIndexes = mongoCollection.Metadata.Indexes.ToList();    
  4.     for (int i = 0; i < listIndexes.Count; i++)    
  5.     {    
  6.         if (listIndexes[i].Key != "_id_")    
  7.         {    
  8.             mongoCollection.Metadata.DropIndex(listIndexes[i].Key);    
  9.         }    
  10.     }    
  11. }  


www.htsjk.Com true http://www.htsjk.com/shujukujc/18886.html NewsArticle 二、维护索引 1. 查询索引 通过索引名查询的方式已有介绍。但有时候,我们可能忘记了索引名,怎么查询呢? 下面提供一个遍历全部索引的方法,打印全...
评论暂时关闭