将 Azure 表存储 TableResult 强制转换为类

And*_*ltz 4 c# azure azure-storage azure-table-storage

我正在编写一种从 Azure 表存储服务检索实体的方法。我需要将实体作为 User 类型而不是 TableResult 返回。以下代码可以编译,但始终返回 Null:

var partitionKey = "user";

            var retrieveOperation = TableOperation.Retrieve<TableEntity>(partitionKey, userName);
            var result = _table.Execute(retrieveOperation);

            if (result == null)
            {
                return null;
            }

            return result.Result as User;
Run Code Online (Sandbox Code Playgroud)

我假设这是因为从 TableResult 到 User 的转换由于某种原因不起作用。像 (User)result.Result 一样转换它实际上会在运行时引发错误。我见过一个在实体列表上使用 Linq 的示例,但是如何投射单个结果?

Tho*_*mas 6

如果您的实体User继承自TableEntity(或实现ITableEntity):

public class User : TableEntity { }
Run Code Online (Sandbox Code Playgroud)

您可以指定结果的类型:

var retrieveOperation = TableOperation.Retrieve<User>(partitionKey, userName);
Run Code Online (Sandbox Code Playgroud)

所以在你的情况下,它看起来像这样:

var partitionKey = "user";
var retrieveOperation = TableOperation.Retrieve<User>(partitionKey, userName);
var result = _table.Execute(retrieveOperation);
if (result == null)
{
    return null;
}
return result.Result as User;
Run Code Online (Sandbox Code Playgroud)

另一种方法是使用该类DynamicTableEntity

var partitionKey = "user";
// The default result type is DynamicTableEntity
var retrieveOperation = TableOperation.Retrieve(partitionKey, userName);
var result = _table.Execute(retrieveOperation);
if (result == null)
{
    return null;
}
return result.Result as DynamicTableEntity;
Run Code Online (Sandbox Code Playgroud)