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;
我假设这是因为从 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;
| 归档时间: | 
 | 
| 查看次数: | 4170 次 | 
| 最近记录: |