如何使用对象持久性模型在 C# 中动态更改 dynamodb 表名

How do I dynamically change dynamodb tablename in c# using object persistence model(如何使用对象持久性模型在 C# 中动态更改 dynamodb 表名)
本文介绍了如何使用对象持久性模型在 C# 中动态更改 dynamodb 表名的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用的是 dynamodb 对象持久性模型.

I was using dynamodb Object Persistence model.

DynamoDBTable("mydynamodbtablename")]
public class mytable
{
  ....
}

现在的问题是,如果我试图让表的名称在运行时动态更改(我通过配置文件获取表名),我会收到错误

problem is now if I tried to make the name of the table to change dynamically in runtime (I get table names through config files), I get errors

var Table_Name = Config.GetTableName();
DynamoDBTable(Table_Name)]
public class mytable
{
  ....
}

错误:属性参数必须是属性参数类型xxx的常量表达式、typeof表达式或数组创建表达式

error: An attribute argument must be a constant expression, typeof expression or array creation expression of an attribute parameter type xxx

有没有办法(简单的方法)让我仍然可以使用 DDB 对象持久性模型并使表名动态化?

Is there a way (easy way) so that I can still use DDB Object Persistence Model and make tables name dynamic?

更新:

好像我没有说清楚ddb持久化模型.这是官方文档http://docs.aws.amazon.com/amazondynamodb/latest/developerguide/CRUDHighLevelExample1.html

It seems that I didn't mentioned ddb persistence model clearly. Here is the official document http://docs.aws.amazon.com/amazondynamodb/latest/developerguide/CRUDHighLevelExample1.html

这是一个例子,说明我们在实际实践中如何使用对象持久性模型

and here is an example of how in real practice do we use object persistence model

var records = await context.LoadAsync<mytable>(somekey);
foreach(var item in records)
{
   ....
}

推荐答案

使用接受 DynamoDBOperationConfigLoadAsync 方法的重载:

Use the overload of the LoadAsync<T> method that accepts a DynamoDBOperationConfig:

var config = new DynamoDBOperationConfig 
{ 
    OverrideTableName = "MyTableName"
};
var records = await context.LoadAsync<mytable>(somekey, config);
foreach(var item in records)
{
   ....
}

这篇关于如何使用对象持久性模型在 C# 中动态更改 dynamodb 表名的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)