當前位置: 首頁>>代碼示例>>C#>>正文


C# TableQuery.Where方法代碼示例

本文整理匯總了C#中Microsoft.WindowsAzure.Storage.Table.TableQuery.Where方法的典型用法代碼示例。如果您正苦於以下問題:C# TableQuery.Where方法的具體用法?C# TableQuery.Where怎麽用?C# TableQuery.Where使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Microsoft.WindowsAzure.Storage.Table.TableQuery的用法示例。


在下文中一共展示了TableQuery.Where方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: GetByIdAsync

        public async Task<Response<JsonObject>> GetByIdAsync(string id)
        {
            if (string.IsNullOrEmpty(id))
                throw new ArgumentNullException("id");

            var table = await DefineTableAsync(CreateCloudTable).ConfigureAwait(false);

            var query =
                new TableQuery<DynamicTableEntity>();
            query.Where(TableQuery.CombineFilters(
                TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, "PK"),
                TableOperators.And,
                TableQuery.GenerateFilterCondition("RowKey", QueryComparisons.Equal, id)));
            query.Where(TableQuery.GenerateFilterConditionForBool("sys_deleted", "ne", true));

            var items = table.ExecuteQuery(query);
            var result = items.ToList();
            var json = new JsonObject();
            var status = HttpStatusCode.NotFound;

            // ReSharper disable UseMethodAny.3
            if (result.Count() <= 0) return new Response<JsonObject>(status, json);
            // ReSharper restore UseMethodAny.3
            json = result.First().ToJsonObject();
            status = HttpStatusCode.OK;

            return new Response<JsonObject>(status, json);
        }
開發者ID:proactima,項目名稱:DynamicFluentAzure,代碼行數:28,代碼來源:FluentAzure.cs

示例2: MapQuery

    private TableQuery<LogEntity> MapQuery(AzureNLogQueryDefinition originalQuery)
    {
      var query = new TableQuery<LogEntity>();
      var filters = new[]
      {
        this.GetPartitionKeyFilter(originalQuery), this.GetMinDateFilter(originalQuery),
        this.GetMaxDateFilter(originalQuery), this.GetLevelFilter(originalQuery)
      }
        .Where(f => !string.IsNullOrWhiteSpace(f))
        .ToArray();

      if (!filters.Any())
      {
        return query;
      }

      var querySt = filters[0];

      for (var i = 1; i < filters.Length; i++)
      {
        querySt = TableQuery.CombineFilters(querySt, TableOperators.And, filters[i]);
      }

      return query.Where(querySt);
    }
開發者ID:caseyjmorris,項目名稱:NLogAzureTableStorageViewer,代碼行數:25,代碼來源:TableQueryer.cs

示例3: GetAllTags

        public IEnumerable<string> GetAllTags(string feed)
        {
            var query = new TableQuery<FeedEntryEntity>();
            query.Where(TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, feed));
            var retrievedResults = Table.ExecuteQuery(query);

            return retrievedResults.Where(x => x.Tag != null).Select(x => x.Tag).Distinct();
        }
開發者ID:CasperTDK,項目名稱:RSSFeed,代碼行數:8,代碼來源:FeedEntryQuery.cs

示例4: GetFeeds

        public IEnumerable<FeedMetaData> GetFeeds(string username)
        {
            var query = new TableQuery<FeedMetaData>();
            query.Where(TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, username));
            var retrievedResults = Table.ExecuteQuery(query);

            return retrievedResults;
        }
開發者ID:CasperTDK,項目名稱:RSSFeed,代碼行數:8,代碼來源:FeedQuery.cs

示例5: GetPublishFeedEntries

        public IEnumerable<FeedEntryEntity> GetPublishFeedEntries(string feed)
        {
            var query = new TableQuery<FeedEntryEntity>();
            query.Where(TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, feed));
            var retrievedResults = Table.ExecuteQuery(query);

            return retrievedResults.Where(x => x.PublishedAt <= DateTime.Now).OrderByDescending(x => x.PublishedAt);
        }
開發者ID:CasperTDK,項目名稱:RSSFeed,代碼行數:8,代碼來源:FeedEntryQuery.cs

示例6: GetAllWithTag

        public IEnumerable<FeedEntryEntity> GetAllWithTag(string feedName, string selectedtag)
        {
            var query = new TableQuery<FeedEntryEntity>();
            var generateFilterCondition = TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, feedName);
            query.Where(generateFilterCondition);
            var retrievedResults = Table.ExecuteQuery(query);

            var result = retrievedResults.Where(x => x.Tag == selectedtag)
                   .ToList();

            return result;
        }
開發者ID:CasperTDK,項目名稱:RSSFeed,代碼行數:12,代碼來源:FeedEntryQuery.cs

示例7: Query

        /// <summary>
        /// Query Table Storage
        /// </summary>
        /// <param name="identifier">Identifier</param>
        /// <param name="version">Version</param>
        /// <param name="fileName">File Name</param>
        /// <returns></returns>
        public virtual async Task<IEnumerable<IDictionary<string, object>>> Query(Guid? identifier = null, string version = null, string fileName = null)
        {
            var partitionFilter = identifier.HasValue ? TableQuery.GenerateFilterCondition(TableStorage.PartitionKey, QueryComparisons.Equal, identifier.Value.ToString()) : null;
            var rowFilter = !string.IsNullOrWhiteSpace(version) ? TableQuery.GenerateFilterCondition(TableStorage.RowKey, QueryComparisons.Equal, version) : null;

            var query = new TableQuery();
            if (null != partitionFilter && null != rowFilter)
            {
                query.Where(TableQuery.CombineFilters(partitionFilter, TableOperators.And, rowFilter));
            }
            else if (null != partitionFilter)
            {
                query.Where(partitionFilter);
            }
            else if (null != rowFilter)
            {
                query.Where(rowFilter);
            }

            var images = await this.table.Query(query);

            if (null != images)
            {
                images = images.Where(i => string.IsNullOrWhiteSpace(fileName) || fileName == (string)i["FileName"]);
                foreach (var data in images)
                {
                    data.Add("Identifier", data[TableStorage.PartitionKey]);
                    data.Add("Version", data[TableStorage.RowKey]);
                    data.Add("CreatedOn", data[TableStorage.Timestamp]);

                    data.Remove(TableStorage.PartitionKey);
                    data.Remove(TableStorage.Timestamp);
                    data.Remove(TableStorage.RowKey);
                    data.Remove(TableStorage.ETag);
                }
            }

            return images;
        }
開發者ID:shoshindes,項目名稱:King.Azure.Imaging,代碼行數:46,代碼來源:QueryDataStore.cs

示例8: GetAllLinks

        public IEnumerable<string> GetAllLinks(string feedName)
        {
            var query = new TableQuery<FeedEntryEntity>();
            var generateFilterCondition = TableQuery.GenerateFilterCondition("PartitionKey", QueryComparisons.Equal, feedName);
            query.Where(generateFilterCondition);
            var retrievedResults = Table.ExecuteQuery(query);

            var result = retrievedResults
                .Where(x => x.Link != null)
                .Select(x => x.Link)
                .ToList();

            return result;
        }
開發者ID:CasperTDK,項目名稱:RSSFeed,代碼行數:14,代碼來源:FeedEntryQuery.cs

示例9: Query

        // NOTE: we don't have a need (yet?) to query commands, as we don't use them to
        // recreate read models, nor we are using it for BI, so we just 
        // expose events.
        public IEnumerable<IEvent> Query(QueryCriteria criteria)
        {
            var context = this.tableClient;
            
            var query = new TableQuery<MessageLogEntity>()
                            .Where(x => x.Kind == StandardMetadata.EventKind); 

            var where = criteria.ToExpression();
            if (where != null)
            {
                query = query.Where(where);
            }

            var table = context.GetTableReference(this.tableName);
            return table.ExecuteQuery(query.AsTableQuery())
                        .ToList()
                        .Select(e => this.serializer.Deserialize<IEvent>(e.Payload));
        }
開發者ID:wayne-o,項目名稱:delete-me,代碼行數:21,代碼來源:AzureEventLogReader.cs

示例10: GetData

        private async Task<TableQuerySegment<DynamicTableEntity>> GetData(string tableName, string filter, TableContinuationToken continuationToken)
        {
            var table = tableClient.GetTableReference(tableName);
            if (!table.Exists())
            {
                throw new ArgumentException("Table does not exist", tableName);
            }

            var query = new TableQuery<DynamicTableEntity>();
            if (!String.IsNullOrEmpty(filter))
            {
                query = query.Where(filter);
            }

            if (continuationToken != null)
            {
                continuationToken.NextTableName = tableName;
            }
            return await table.ExecuteQuerySegmentedAsync(query, continuationToken);
        }
開發者ID:rajmannartech,項目名稱:azure-web-storage-explorer,代碼行數:20,代碼來源:StorageRepository.cs

示例11: SearchCheeseReviewsAsync

		public async Task<List<CheeseReviewEntity>> SearchCheeseReviewsAsync (string emailAddress)
		{
			List<CheeseReviewEntity> results = new List<CheeseReviewEntity> ();

			try {
				if (client == null)
					await InitializeCloudClientAsync ();
				
				var table = client.GetTableReference (reviewTable); 

				// Generate a query
				var query = new TableQuery<CheeseReviewEntity> ();
							
				// Looking for an exact match
				query.Where (TableQuery.GenerateFilterCondition ("PartitionKey", QueryComparisons.Equal, emailAddress));

				// This version of the Table Storage NuGet only has the option
				// of returning a subset of the entire entity set at a time. 
				// We could use the TableContinuation token along with a loop to get
				// everything out - but we'll just go with the first return
				TableContinuationToken continueToken = null;

				// Execute the query
				var s = await table.ExecuteQuerySegmentedAsync (query, continueToken);

				continueToken = s.ContinuationToken;

				var searchResults = s.Results;

				results.AddRange (s.Results);

			} catch (Exception ex) {
				var exMsg = ex.ToString ();
			}

			return results;
		}
開發者ID:codemillmatt,項目名稱:CheesedTables,代碼行數:37,代碼來源:CheeseTableService.cs

示例12: QueryTriples

 private IEnumerable<Triple> QueryTriples(string dimension, string pk1)
 {
     var query = new TableQuery<GraphEntity>();
     query.Where(string.Format("PartitionKey gt '{1}~{0}~' and PartitionKey lt '{1}~{0}~~'", KeyEncoder(pk1), dimension));
     return table.ExecuteQuery(query).Select(entity => entity.ToTriple());
 }
開發者ID:richorama,項目名稱:AzureStorageExtensions,代碼行數:6,代碼來源:Graph.cs

示例13: GenerateListTablesQuery

        private TableQuery GenerateListTablesQuery(string prefix, int? maxResults)
        {
            TableQuery query = new TableQuery();

            if (!string.IsNullOrEmpty(prefix))
            {
                // Append Max char to end  '{' is 1 + 'z' in AsciiTable
                string uppperBound = prefix + '{';

                query = query.Where(TableQuery.CombineFilters(
                    TableQuery.GenerateFilterCondition(TableConstants.TableName, QueryComparisons.GreaterThanOrEqual, prefix),
                    TableOperators.And,
                    TableQuery.GenerateFilterCondition(TableConstants.TableName, QueryComparisons.LessThan, uppperBound)));
            }

            if (maxResults.HasValue)
            {
                query = query.Take(maxResults.Value);
            }

            return query;
        }
開發者ID:DaC24,項目名稱:azure-storage-net,代碼行數:22,代碼來源:CloudTableClient.cs

示例14: AppendLogs

        private bool AppendLogs(CloudStorageAccount storageAccount, string partition, List<QLog> result, QLogBrowserSettings settings)
        {
            string[] partitionSplit = partition.Split(',');
            string tableName = partitionSplit[0];
            string tablePartition = partitionSplit[1];

            string postfix = StorageConnectionHelper.GetPostfix(settings);
            if(!String.IsNullOrWhiteSpace(postfix))
                tableName = String.Format("qlog{0}{1}", postfix, tableName);
            else
                tableName = String.Format("qlog{0}", tableName);

            CloudTableClient tableClient = storageAccount.CreateCloudTableClient();
            CloudTable table = tableClient.GetTableReference(tableName);
            if (table.Exists())
            {
                TableQuery<QLog> logsQuery = new TableQuery<QLog>();
                string filter = GetFilters(tablePartition, settings);
                logsQuery.Where(filter);

                foreach (QLog log in table.ExecuteQuery(logsQuery))
                {
                    if (!String.IsNullOrWhiteSpace(settings.ContainingText))
                        if(!log.Message.ToLower().Contains(settings.ContainingText.ToLower()))
                            continue;

                    log.CreatedOn = log.CreatedOn.ToLocalTime();
                    result.Add(log);
                    if (result.Count >= settings.Limit)
                        return false;
                }

                return true;
            }
            else
                return true;
        }
開發者ID:sobanieca,項目名稱:QLog,代碼行數:37,代碼來源:LogRepository.cs

示例15: DoEscapeTest

        private void DoEscapeTest(string data, bool useBatch, bool includeKey)
        {
            DynamicTableEntity ent = new DynamicTableEntity(includeKey ? "temp" + data : "temp", Guid.NewGuid().ToString());
            ent.Properties.Add("foo", new EntityProperty(data));

            // Insert
            if (useBatch)
            {
                TableBatchOperation batch = new TableBatchOperation();
                batch.Insert(ent);
                currentTable.ExecuteBatch(batch);
            }
            else
            {
                currentTable.Execute(TableOperation.Insert(ent));
            }

            // Retrieve
            TableResult res = null;
            if (useBatch)
            {
                TableBatchOperation batch = new TableBatchOperation();
                batch.Retrieve(ent.PartitionKey, ent.RowKey);
                res = (currentTable.ExecuteBatch(batch))[0];
            }
            else
            {
                res = currentTable.Execute(TableOperation.Retrieve(ent.PartitionKey, ent.RowKey));
            }

            // Check equality
            DynamicTableEntity retrievedEntity = res.Result as DynamicTableEntity;
            Assert.IsNotNull(retrievedEntity);
            Assert.AreEqual(ent.PartitionKey, retrievedEntity.PartitionKey);
            Assert.AreEqual(ent.RowKey, retrievedEntity.RowKey);
            Assert.AreEqual(ent.ETag, retrievedEntity.ETag);
            Assert.AreEqual(ent.Properties.Count, retrievedEntity.Properties.Count);
            Assert.AreEqual(ent.Properties["foo"], retrievedEntity.Properties["foo"]);

            // Query using data filter
            TableQuery query = new TableQuery();
            query.Where(string.Format(
                "(PartitionKey eq \'{0}\') and (RowKey eq \'{1}\') and (foo eq \'{2}\')",
                ent.PartitionKey,
                ent.RowKey,
                data.Replace("\'", "\'\'")));

            retrievedEntity = currentTable.ExecuteQuery(query).Single();

            Assert.IsNotNull(retrievedEntity);
            Assert.AreEqual(ent.PartitionKey, retrievedEntity.PartitionKey);
            Assert.AreEqual(ent.RowKey, retrievedEntity.RowKey);
            Assert.AreEqual(ent.ETag, retrievedEntity.ETag);
            Assert.AreEqual(ent.Properties.Count, retrievedEntity.Properties.Count);
            Assert.AreEqual(ent.Properties["foo"], retrievedEntity.Properties["foo"]);

            // Merge
            ent.Properties.Add("foo2", new EntityProperty("bar2"));

            if (useBatch)
            {
                TableBatchOperation batch = new TableBatchOperation();
                batch.Merge(ent);
                currentTable.ExecuteBatch(batch);
            }
            else
            {
                currentTable.Execute(TableOperation.Merge(ent));
            }

            // Retrieve
            if (useBatch)
            {
                TableBatchOperation batch = new TableBatchOperation();
                batch.Retrieve(ent.PartitionKey, ent.RowKey);
                res = (currentTable.ExecuteBatch(batch))[0];
            }
            else
            {
                res = currentTable.Execute(TableOperation.Retrieve(ent.PartitionKey, ent.RowKey));
            }

            retrievedEntity = res.Result as DynamicTableEntity;
            Assert.AreEqual(ent.PartitionKey, retrievedEntity.PartitionKey);
            Assert.AreEqual(ent.RowKey, retrievedEntity.RowKey);
            Assert.AreEqual(ent.ETag, retrievedEntity.ETag);
            Assert.AreEqual(ent.Properties.Count, retrievedEntity.Properties.Count);
            Assert.AreEqual(ent.Properties["foo"], retrievedEntity.Properties["foo"]);

            // Replace
            ent.Properties.Remove("foo2");
            ent.Properties.Add("foo3", new EntityProperty("bar3"));

            if (useBatch)
            {
                TableBatchOperation batch = new TableBatchOperation();
                batch.Replace(ent);
                currentTable.ExecuteBatch(batch);
            }
            else
//.........這裏部分代碼省略.........
開發者ID:huoxudong125,項目名稱:azure-sdk-for-net,代碼行數:101,代碼來源:TableEscapingTests.cs


注:本文中的Microsoft.WindowsAzure.Storage.Table.TableQuery.Where方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。