при попытке ИЗБРАННОГО КОЛИЧЕСТВА (1) ОТ group_relations это будет немного быстрее, потому что это не попытается получить информацию из столбцов.
КОЛИЧЕСТВО (1) раньше было быстрее, чем КОЛИЧЕСТВО (*), но это больше не верно, начиная с современного DBMS достаточно умны, чтобы знать, что Вы не хотите знать о столбцах
Все это легко доступно с помощью DTE в Visual Studio SDK.
Вы можете получить список проектов в решении, используя интерфейс Projects .
Вы можете получить список элементов в проекте, используя ProjectItem ].
Для получения дополнительной информации я бы рекомендовал прочитать на Controlling Projects and Solutions .
Спасибо, Рид; статья, на которую вы указали ссылку, позволила мне получить доказательство концепции за пару минут.
Поскольку я чувствую, что это связано, вот итерация и рекурсивные средства, с помощью которых я собрал ProjectItems. Я сделал это в DXCore, но та же идея применима к необработанному Visual Studio SDK (DXCore - это просто более красивая оболочка над SDK). Объекты «Решение», «Проекты», «Проект» и «ProjectItem» находятся прямо здесь, в EnvDTE.
Настройка проектов
EnvDTE.Solution solution = CodeRush.ApplicationObject.Solution;
EnvDTE.Projects projects = solution.Projects;
Итерация по проектам для извлечения элементов проекта
var projects = myProjects.GetEnumerator();
while (projects.MoveNext())
{
var items = ((Project)projects.Current).ProjectItems.GetEnumerator();
while (items.MoveNext())
{
var item = (ProjectItem)items.Current;
//Recursion to get all ProjectItems
projectItems.Add(GetFiles(item));
}
}
Наконец, рекурсия, которую я делаю для получения все элементы проекта в активном решении
ProjectItem GetFiles(ProjectItem item)
{
//base case
if (item.ProjectItems == null)
return item;
var items = item.ProjectItems.GetEnumerator();
while (items.MoveNext())
{
var currentItem = (ProjectItem)items.Current;
projectItems.Add(GetFiles(currentItem));
}
return item;
}