Подтвердить что ты не робот

Получить все записи из лазурного хранилища таблиц

Использование этого кодового блока

try
{
    StorageCredentials creds = new StorageCredentials(accountName, accountKey);
    CloudStorageAccount account = new CloudStorageAccount(creds, useHttps: true);

    CloudTableClient client = account.CreateCloudTableClient();
    CloudTable table = client.GetTableReference("serviceAlerts");

    TableOperation retrieveOperation = TableOperation.Retrieve<ServiceAlertsEntity>("ServiceAlerts", "b9ccd839-dd99-4358-b90f-46781b87f933");

    TableResult query = table.Execute(retrieveOperation);

    if (query.Result != null)
    {
        outline = outline + ((ServiceAlertsEntity) query.Result).alertMessage + " * ";
    }
    else
    {
        Console.WriteLine("No Alerts");
    }
}
catch (Exception ex)
{
    Console.WriteLine(ex);
}

Я могу получить единственную запись с разделом и строкой row, указанными в извлечении.

Есть ли способ получить все записи, которые хранятся в разделе ServiceAlerts?

Я попробовал подстановочный знак (*) для второго параметра

TableOperation retrieveOperation = TableOperation.Retrieve<ServiceAlertsEntity>(
      "ServiceAlerts","b9ccd839-dd99-4358-b90f-46781b87f933");

но ничего не возвращает.

4b9b3361

Ответ 1

Вам нужно указать TableQuery, это даст вам все сущности или вы можете указать TableQuery.GenerateFilterCondition для фильтрации строк.

TableQuery<ServiceAlertsEntity> query = new TableQuery<ServiceAlertsEntity>();

foreach (ServiceAlertsEntity entity in table.ExecuteQuery(query))
{
    Console.WriteLine("{0}, {1}\t{2}\t{3}", entity.PartitionKey, entity.RowKey,
                        entity.Field1, entity.Field2);
}

Ответ 2

Если вам нужен дополнительный контроль над возвращаемыми записями, вы можете использовать ExecuteQuerySegmentedAsync для извлечения данных на странице (около 1000 записей) за раз.

    var alerts = new List<ServiceAlertsEntity>();

    var query = new TableQuery<ServiceAlertsEntity>();
    TableContinuationToken continuationToken = null;
    do
    {
        var page = await table.ExecuteQuerySegmentedAsync(query, continuationToken);
        continuationToken = page.ContinuationToken;
        alerts.AddRange(page.Results);
    }
    while (continuationToken != null);

Или если вам нужно ограничить свои результаты, например, по ключу раздела вы можете добавить условие фильтра, добавив предложение Where к запросу в приведенном выше коде.

    var pk = "abc";
    var filterPk = TableQuery.GenerateFilterCondition(
        nameof(ServiceAlertsEntity.PartitionKey),
        QueryComparisons.Equal, pk);

    var query = new TableQuery<ServiceAlertsEntity>().Where(filterPk);

Справочник по MS Azure

Ответ 4

Я сделал тот же процесс, используя общий класс. С помощью функции приложения я достиг этого. пожалуйста, найдите следующие коды. Сначала я создал приложение-функцию MyEventhubTrigger.cs

using Microsoft.ApplicationInsights;
using Microsoft.ApplicationInsights.DataContracts;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.ServiceBus;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
using System;
using AzureMonitorFunctions.WebHook;



namespace MyFunctions
{
    public static class MyEventhubTrigger
    {               

        [FunctionName("MyEventhubTrigger")]       
       public static async void Run([EventHubTrigger("%EventHubName%", Connection = "EventHubConnectionString", ConsumerGroup = "devicestatuscg")] string myEventHubMessage, DateTime enqueuedTimeUtc, Int64 sequenceNumber, string offset, ILogger log)
        {           
            log.LogInformation($"C# Event Hub trigger function processed a message: {myEventHubMessage}");
            try
            {                 
                StorageTableOperation<StorageTable> tableObj = new StorageTableOperation<StorageTable>("EventhubMessages");
                Eventhubstorage Eventhubdada = tableObj.GetTableData("Eventhub", "DeviceStatus");
                if (Eventhubdada.EnqueuedTime < enqueuedTimeUtc)
                {                    
                        Eventhubdada.EnqueuedTime = enqueuedTimeUtc;
                        Eventhubdada.Offset = offset;
                        Eventhubdada.Sequence = sequenceNumber;
                        await tableObj.UpdateTableData("Eventhub", "DeviceStatus", Eventhubdada);
                    }
                }

            }
            catch (Exception ex)
            {
                log.LogInformation(ex.ToString());
            }
        }
    }
}

Теперь у меня есть хранилище таблиц в учетной записи хранения Azure. И добавьте то же поле в файл свойств. StorageTable.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.WindowsAzure.Storage.Table;

namespace MyFunctions
{
    public class StorageTable : TableEntity
    {
        public StorageTable()
        {
        }
        public StorageTable(string PKey, string RKey)
        {
            PartitionKey = PKey;
            RowKey = RKey;
        }

        public DateTime EnqueuedTime { get; set; }
        public Int64 Sequence { get; set; }
        public string Offset { get; set; }
    }
}

Теперь я создал класс, который может принимать любой класс свойств TableEntity и выполнить следующую операцию Get/insert/Update. Найдите следующий код для StorageTableOperation.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.WindowsAzure.Storage;
using Microsoft.WindowsAzure.Storage.Table;
using System.Threading.Tasks;


namespace MyFunctions
{
    public class StorageTableOperation<T> where T : ITableEntity
    {       
        internal CloudTable cloudTable;        

        public StorageTableOperation(string tableName)
        {
            string connectionString = Environment.GetEnvironmentVariable("AzureWebJobsStorage");
            CloudStorageAccount storageAccount = CloudStorageAccount.Parse(connectionString);
            CloudTableClient client = storageAccount.CreateCloudTableClient();
            cloudTable = client.GetTableReference(tableName);
        }
        public T GetTableData(string PartitionKey,string RowKey)
        {           
            TableOperation retOp = TableOperation.Retrieve<T>(PartitionKey, RowKey);
            TableResult result = cloudTable.Execute(retOp);
            T tableData = (T)result.Result;


            return tableData;
        }

        public async Task<bool> UpdateTableData(string PartitionKey, string RowKey, T tableData)
        {
            try
            {               
                TableOperation operation = TableOperation.InsertOrMerge(tableData);
                TableResult tableResult = await cloudTable.ExecuteAsync(operation);
                return true;
            }
            catch(Exception ex)
            {
                return false;
            }

        }

    }
}