我正在编写一种从 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;
我假设这是因为从 TableResult 到 User 的转换由于某种原因不起作用。像 (User)result.Result 一样转换它实际上会在运行时引发错误。我见过一个在实体列表上使用 Linq 的示例,但是如何转换单个结果?
最佳答案
如果您的实体User
继承自TableEntity
(或实现ITableEntity
):
public class User : TableEntity { }
您可以指定结果的类型:
var retrieveOperation = TableOperation.Retrieve<User>(partitionKey, userName);
所以在你的情况下,它看起来像这样:
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;
另一种方法是使用 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;
关于c# - 将 Azure 表存储 TableResult 强制转换为类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36379896/