本文整理汇总了C#中Query.RunQuery方法的典型用法代码示例。如果您正苦于以下问题:C# Query.RunQuery方法的具体用法?C# Query.RunQuery怎么用?C# Query.RunQuery使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Query
的用法示例。
在下文中一共展示了Query.RunQuery方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetWorkItemsFrom
public WorkItem[] GetWorkItemsFrom(string workItemNumber)
{
string query = string.Format(
"SELECT * FROM workitems WHERE ([Team Project] = '{0}' AND [ID] >= {1} AND [Work Item Type] IN ({2}))",
_settings.ProjectsMapping[0].Key,
workItemNumber,
_settings.EntityMapping.ToWorkItemsString());
var workItemsQuery = new Query(_workItemStore, query, null, false);
var workItems = workItemsQuery.RunQuery();
return workItems.Cast<WorkItem>().ToArray();
}
示例2: GetWorkItemsBetween
public WorkItem[] GetWorkItemsBetween(string projectName, string[] importedTypes, int minId, int maxId, DateTime lastSync)
{
string query = string.Format(
"SELECT * FROM workitems WHERE ([Team Project] = '{0}' AND [ID] >= {1} AND [ID] <= {2} AND [Changed Date] > '{3}' AND [Work Item Type] IN ({4}))",
projectName,
minId,
maxId == -1 ? Int32.MaxValue : maxId,
lastSync,
importedTypes.ToString(x => string.Concat("'", x, "'"), ","));
var workItemsQuery = new Query(_workItemStore, query, null, false);
var workItems = workItemsQuery.RunQuery();
return workItems.Cast<WorkItem>().ToArray();
}
示例3: ProcessWorkItemRelationships
/// <summary>
/// Method for processing work items down to the changesets that are related to them
/// </summary>
/// <param name="wi">Work Item to process</param>
/// <param name="outputFile">File to write the dgml to</param>
/// <param name="vcs">Version Control Server which contains the changesets</param>
public void ProcessWorkItemRelationships()
{
_full = true;
//Pull every work item for the project
Query q = new Query(_wis, string.Format("SELECT [System.Id], [System.WorkItemType], [System.Title], [System.AssignedTo], "
+ "[System.State] FROM WorkItems WHERE [System.TeamProject] = '{0}'", _projectName));
WorkItemCollection wic = q.RunQuery();
WorkItem[] workItems = new WorkItem[wic.Count];
for (int i = 0; i < wic.Count; i++)
workItems[i] = wic[i];
Process(workItems);
}
示例4: QueryWorkItems
public List<WorkItem> QueryWorkItems(string queryPath, Action<int> progressReportHandler)
{
List<string> paths = queryPath.Split(Path.DirectorySeparatorChar).ToList();
if (paths.Count == 1)
paths = queryPath.Split(Path.AltDirectorySeparatorChar).ToList();
Project project = m_workItemStore.Projects[paths[0]];
paths.RemoveAt(0);
QueryItem item = project.QueryHierarchy;
foreach (string path in paths)
{
var queryFolder = item as QueryFolder;
item = queryFolder[path];
}
if (item == null)
throw new InvalidOperationException("Invalid Query Path.");
string queryText = m_workItemStore.GetQueryDefinition(item.Id).QueryText.Replace("@project", "'" + project.Name + "'");
var query = new Query(m_workItemStore, queryText);
if (query.IsLinkQuery)
{
var queryResults = query.RunLinkQuery();
var workItemIds = new List<int>();
foreach (var queryResult in queryResults)
{
workItemIds.Add(queryResult.SourceId);
workItemIds.Add(queryResult.TargetId);
}
using (var wiqlAccessor = new TfsWiqlAccessor(m_tfsAccessor))
{
return wiqlAccessor.QueryWorkItemsByIds(workItemIds, progressReportHandler);
}
}
var qResult = query.RunQuery();
var result = new List<WorkItem>(qResult.Count);
for (int i = 0; i < qResult.Count; i++)
{
result.Add(qResult[i]);
}
return result;
}
示例5: RunQuery
public IEnumerable<WorkItem> RunQuery(QueryDefinition queryDefinition)
{
QueryDefinition parsedQueryDefinition = macroParser.Replace(queryDefinition);
var query = new Query(currentContext.CurrentWorkItemStore, parsedQueryDefinition.QueryText);
if (query.IsLinkQuery)
{
var queryResults = query.RunLinkQuery();
return from l in queryResults.OfType<WorkItemLinkInfo>()
select currentContext.CurrentWorkItemStore.GetWorkItem(l.TargetId);
}
else
{
var queryResults = query.RunQuery();
return queryResults.OfType<WorkItem>();
}
}
示例6: GetWorkItemsFromLinkQuery
private static WorkItemCollection GetWorkItemsFromLinkQuery(WorkItemStore store, Query workItemQuery,
IEnumerable<FieldDefinition> fieldDefinitions)
{
var workItemInfo = workItemQuery.RunLinkQuery();
var allWorkItemIds = workItemInfo.Select(wi => wi.TargetId).Distinct().ToArray();
if (fieldDefinitions == null)
{
return store.Query(allWorkItemIds, "SELECT * FROM WorkItems");
}
else
{
IEnumerable<string> numericFieldDefinitionNames =
fieldDefinitions.Select(fd => "[" + fd.ReferenceName + "]");
string select = "SELECT " + string.Join(", ", numericFieldDefinitionNames) + " FROM WorkItems";
var actualWorkItemQuery = new Query(store, select, allWorkItemIds);
return actualWorkItemQuery.RunQuery();
}
}
示例7: GetWorkItem
private WorkItem GetWorkItem(int id)
{
Query q = new Query(workItemStore, "SELECT System.ID FROM WorkITems WHERE [System.ID] = '"+id+"'");
WorkItemCollection wic = q.RunQuery();
if (wic.Count != 0)
{
return wic[0];
}
else
{
return null;
}
}
示例8: GetWorkItemTree
private IList<WorkItemViewModel> GetWorkItemTree(string query)
{
var treeQuery = new Query(_workItemStore, query);
var links = treeQuery.RunLinkQuery();
var workItemIds = links.Select(l => l.TargetId).ToArray();
query = "SELECT * FROM WorkItems";
var flatQuery = new Query(_workItemStore, query, workItemIds);
var workItemCollection = flatQuery.RunQuery();
var workItemList = new List<WorkItemViewModel>();
for (int i = 0; i < workItemCollection.Count; i++)
{
var workItem = workItemCollection[i];
if (workItem.Type.Name == "Requirement")
{
var model = new WorkItemViewModel()
{
Id = workItem.Id,
RequestNo = workItem.Fields["MyCompany.RequestNumber"].Value.ToString(),
Title = workItem.Title,
WorkItemType = workItem.Fields["MyCompany.WorkItemType"].Value.ToString(),
Priority = workItem.Fields["MyCompany.Priority"].Value.ToString()
};
workItemList.Add(model);
}
else
{
switch (workItem.Type.Name)
{
case "Task":
var task = new TFSTask()
{
Name = workItem.Title,
Activity = workItem.Fields["MyCompany.Activity"].Value.ToString(),
Start = (DateTime?)workItem.Fields["MyCompany.ActivityStart"].Value,
Due = (DateTime?)workItem.Fields["MyCompany.ActivityFinish"].Value,
Status = workItem.State
};
workItemList.Last().Tasks.Add(task);
break;
case "Issue":
var issue = new TFSIssue()
{
Name = workItem.Title,
Created = workItem.CreatedDate,
Due = (DateTime?)workItem.Fields["MyCompany.ActivityDue"].Value,
Status = workItem.State
};
workItemList.Last().Issues.Add(issue);
break;
default:
break;
}
}
}
return workItemList;
}
示例9: ExecuteQueryLinkTypes
public static bool ExecuteQueryLinkTypes(QueryDefinition qdef, string ProjectName, out int[] qdata)
{
Hashtable context = new Hashtable();
StringBuilder strb = new StringBuilder();
List<int> lqdata = new List<int>();
context.Add("project", ProjectName); //@me, @today are filled automatically
var query = new Query(Utilities.wistore, qdef.QueryText, context);
if (query.IsLinkQuery)
{
foreach (var wilnk in query.RunLinkQuery())
{
lqdata.Add(wilnk.TargetId);
lqdata.Add(wilnk.SourceId);
Utilities.OutputCommandString(string.Format("ParentID={0}, WorkItemID={1}", wilnk.SourceId, wilnk.TargetId));
}
lqdata = lqdata.Distinct().ToList();
}
else
{
foreach (WorkItem wi in query.RunQuery())
{
lqdata.Add(wi.Id);
Utilities.OutputCommandString(string.Format("WorkItemID={0}, Title={1}", wi.Id, wi.Title));
}
}
qdata = lqdata.ToArray();
return false;
}
示例10: BwDoWork
private void BwDoWork(object sender, DoWorkEventArgs e)
{
// Logger.Write("Entering BwDoWork method");
var newWorkItems = new ObservableCollection<WorkItem>();
if (!string.IsNullOrEmpty((string) e.Argument))
{
var queryString = string.Format("SELECT * FROM WorkItems WHERE [System.IterationPath] = '{0}'", e.Argument);
var q = new Query(workItemStoreService, queryString);
if (q.IsLinkQuery)
{
var queryResults = q.RunLinkQuery();
foreach (WorkItemLinkInfo i in queryResults)
{
var wi = workItemStoreService.GetWorkItem(i.TargetId);
newWorkItems.Add(wi);
}
}
else
{
var queryResults = q.RunQuery();
foreach (WorkItem workitem in queryResults)
{
newWorkItems.Add(workitem);
}
}
}
e.Result = newWorkItems;
}
示例11: RunQuery
private List<WorkItem> RunQuery(Query query)
{
var queryResults = query.RunQuery();
return queryResults.Cast<WorkItem>().ToList();
}
示例12: Main
static void Main(String[] args)
{
// Connect to Team Foundation Server
// Server is the name of the server that is running the application tier for Team Foundation.
// Port is the port that Team Foundation uses. The default port is 8080.
// VDir is the virtual path to the Team Foundation application. The default path is tfs.
string tfsServerAddress = "http://tfs13dev:8080/tfs/";
//Create class object
ConnectionAndInformation.ConnectionAndInformation cai = new ConnectionAndInformation.ConnectionAndInformation();
//create URI
cai.createUriFromStringAddress(tfsServerAddress);
//TfsConfigurationServer
cai.createConfigurationServer(cai.uriGetSet);
//create catalog of team project collections
cai.createCatalogTeamProjectCollections(cai.tfsConfigurationServerGetSet);
cai.getCatalogTeamProjects(cai.catalogNodesGetSet);
List<string> list = new List<string>();
string info = String.Empty;
var qText = String.Format(@"SELECT * FROM WorkItems WHERE [System.TeamProject] = 'TSDL' ORDER BY [System.Id]");
//TfsTeamProjectCollection tpc = TfsTeamProjectCollectionFactory.GetTeamProjectCollection(new Uri("http://tfs13dev:8080/tfs/"));
var tpc = TfsTeamProjectCollectionFactory.GetTeamProjectCollection(new Uri("http://tfs13dev:8080/tfs/"));
var service = tpc.GetService<WorkItemStore>();
//TfsTeamProjectCollection tpc = new TfsTeamProjectCollection(new Uri("http://tfs13dev:8080/tfs/"));
WorkItemStore workItemStore = (WorkItemStore)tpc.GetService(typeof(WorkItemStore));
// WorkItemCollection queryResults = workItemStore.Query("SELECT * FROM WorkItems WHERE [System.TeamProject] = LEAP");
// WorkItemCollection queryResults = workItemStore.Query("SELECT [System.Id], [System.WorkItemType], [System.Title], [System.AssignedTo] FROM WorkItems WHERE [System.TeamProject] = 'ODS' ORDER by [System.Id] desc");
//WorkItemStore workItemStore = new WorkItemStore(tpc);
//Project teamProject = workItemStore.Projects["ODS"];
//WorkItemType wit = teamProject.WorkItemTypes[""];
Project teamProject = workItemStore.Projects["TSDL"];
/*
WorkItemType workItemType = teamProject.WorkItemTypes["Requirement"];
WorkItem userStory = new WorkItem(workItemType)
{
Title = "Recently ordered menu",
Description = "As a return customer, I want to see items that I've recently ordered."
};
userStory.Save();
*/
Query query = new Query(service, qText);
var workItems = query.RunQuery();
foreach(WorkItem workItem in workItems)
{
list.Add(workItem.Id + " - " + workItem.Title);
}
list.ForEach(i => Console.Write("{0}\n", i));
/*
WorkItemCollection queryResults = workItemStore.Query("SELECT * FROM WorkItems WHERE [System.TeamProject] = 'TSDL' ORDER BY [System.Id]");
foreach(WorkItem wi in queryResults)
{
Console.WriteLine("QueryResults: " + wi);
}
*/
}
示例13: RunQuery
/// <summary>
/// Executes the selected work item query
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void RunQuery()
{
Mouse.OverrideCursor = Cursors.Wait;
WorkItemCollection wic;
string finalQuery = string.Empty;
TreeNode item = (TreeNode)tvwQueries.SelectedItem;
if (item.Tag.GetType() == typeof(QueryDefinition))
{
_queryResults = new List<WorkItemData>();
//var projectName = cboProjects.Text;
var si = cboProjects.SelectedItem as ProjectInfo;
var projectName = si.Name;
QueryDefinition qd = (QueryDefinition)item.Tag;
//Replace the @Project and @Me options if they exist in the query
finalQuery = qd.QueryText;
if (finalQuery.IndexOf("@project") > 0)
finalQuery = finalQuery.Replace("@project", "'" + projectName + "'");
if (finalQuery.IndexOf("@Me") > 0)
finalQuery = finalQuery.Replace("@Me", System.Security.Principal.WindowsIdentity.GetCurrent().Name);
Query query = new Query(_wis, finalQuery);
if (query.IsTreeQuery || query.IsLinkQuery)
{
_queryResults = GetHierarchicalResults(query);
}
else
{
wic = query.RunQuery();
for (int i = 0; i < wic.Count; i++)
{
_queryResults.Add(new WorkItemData() { ID = wic[i].Id, WI = wic[i] });
}
}
LoadListView(_queryResults, query);
}
Mouse.OverrideCursor = null;
}
示例14: QueryWorkItems
public List<WorkItem> QueryWorkItems(
string wiqlString,
Dictionary<string, object> paramValues,
Dictionary<string, List<object>> complexParamValues,
Action<int> progressReportHandler)
{
if (complexParamValues != null && complexParamValues.Count > 0)
wiqlString = UpdateParams(wiqlString, paramValues, complexParamValues);
var query = new Query(m_workItemStore, wiqlString, paramValues ?? new Dictionary<string, object>(0));
var queryResult = query.RunQuery();
var result = new List<WorkItem>(queryResult.Count);
for (int i = 0; i < queryResult.Count; i++)
{
var wi = queryResult[i];
wi.SyncToLatest();
result.Add(wi);
if (progressReportHandler != null)
progressReportHandler(i * 100 / queryResult.Count);
}
return result;
}
示例15: ItemOnSelected
public void ItemOnSelected(object sender, RoutedEventArgs e)
{
try
{
var item = (TreeViewItem)sender;
if (Query != null)
{
var queryDef = (QueryDefinition)project.QueryHierarchy.Find((Guid)item.Tag);
queryDef.QueryText = queryDef.QueryText.Replace("@project", "'" + project.Name + "'");
Query(queryDef);
var query = new Query(ItemStore, queryDef.QueryText);
Int32 count = 0;
if (query.IsLinkQuery)
{
var queryResults = query.RunLinkQuery();
count = queryResults.Count();
}
else
{
var queryResults = query.RunQuery();
count = queryResults.Count;
}
QueryTypes type;
switch (queryDef.QueryType)
{
case QueryType.List: type = QueryTypes.FView; break;
case QueryType.OneHop: type = QueryTypes.DView; break;
case QueryType.Tree: type = QueryTypes.HView; break;
default: type = QueryTypes.None; break;
}
item.Header = CreateTreeItem(queryDef.Name + " [" + count + "]", type);
QueryReport.correctQuery = true;
}
}
catch (InvalidQueryTextException ex)
{
MessageBox.Show(ex.Message, ResourceHelper.GetResourceString("ERROR_TEXT"), MessageBoxButton.OK, MessageBoxImage.Error);
QueryReport.correctQuery = false;
}
}