当地图尚不存在时,如何设置 DynamoDB 地图属性值

本文介绍了当地图尚不存在时,如何设置 DynamoDB 地图属性值的处理方法,对大家解决问题具有一定的参考价值

问题描述

如何将属性更新"到 DynamoDB 行.例如.SET address.state = "MA" 对于某些项目,当 address 尚不存在时?

How do you "upsert" a property to a DynamoDB row. E.g. SET address.state = "MA" for some item, when address does not yet exist?

我觉得我遇到了先有鸡还是先有蛋的问题,因为 DynamoDB 不允许您提前定义草率的架构.

I feel like I'm having a chicken-and-egg problem because DynamoDB doesn't let you define a sloppy schema in advance.

如果 address DID 已经存在于该项目上,类型为 M(用于地图),互联网告诉我我可以发出 UpdateExpression,如:

If address DID already exist on that item, of type M (for Map), the internet tells me I could issue an UpdateExpression like:

SET #address.#state = :value

#address#state:value 适当地映射到 addressstateMA.

with #address, #state, and :value appropriately mapped to address, state, and MA, respectively.

但如果 address 属性确实 已经存在,则会报错:

But if the address property does not already exist, this gives an error:

'''ValidationException:更新表达式中提供的文档路径对更新无效'''

''' ValidationException: The document path provided in the update expression is invalid for update '''

所以.. 看来我要么需要:

So.. it appears I either need to:

  1. 想办法更新"address.state(例如,SET address = {}; SET address.state = 'MA' 在单个命令中)
  1. Figure out a way to "upsert" address.state (e.g., SET address = {}; SET address.state = 'MA' in a single command)

  1. 发出三个 (!!!) 我尝试的往返,SET address = {}; 失败,然后再试一次.
  1. Issue three (!!!) roundtrips in which I try it, SET address = {}; on failure, and then try it again.

如果是后者....如何设置空白地图?!?

If the latter.... how do I set a blank map?!?

呃..我喜欢 Dynamo,但除非我遗漏了一些明显的东西,否则这有点疯狂..

Ugh.. I like Dynamo, but unless I'm missing something obvious this is a bit crazy..

推荐答案

你可以通过两次往返来完成,第一次有条件地为 address 设置一个空映射,如果它不存在,第二个设置 state:

You can do it with two round trips, the first conditionally sets an empty map for address if it doesn't already exist, and the second sets the state:

db.update({
    UpdateExpression: 'SET #a = :value',
    ConditionExpression: 'attribute_not_exists(#a)',
    ExpressionAttributeValues: {
        ":value": {},
    },
    ExpressionAttributeNames: {
        '#a': 'address'
    }
}, ...);

然后:

db.update({
    UpdateExpression: 'SET #a.#b = :v',
    ExpressionAttributeNames: {
        '#a': 'address',
        '#b': 'state'
    },
    ExpressionAttributeValues: {
        ':v': 'whatever'
    }
}, ...);

这篇关于当地图尚不存在时,如何设置 DynamoDB 地图属性值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,WP2

admin_action_{$_REQUEST[‘action’]}

do_action( "admin_action_{$_REQUEST[‘action’]}" )动作钩子::在发送“Action”请求变量时激发。Action Hook: Fires when an ‘action’ request variable is sent.目录锚点:#说明#源码说明(Description)钩子名称的动态部分$_REQUEST['action']引用从GET或POST请求派生的操作。源码(Source)更新版本源码位置使用被使用2.6.0 wp-admin/admin.php:...

日期:2020-09-02 17:44:16 浏览:1167

admin_footer-{$GLOBALS[‘hook_suffix’]}

do_action( "admin_footer-{$GLOBALS[‘hook_suffix’]}", string $hook_suffix )操作挂钩:在默认页脚脚本之后打印脚本或数据。Action Hook: Print scripts or data after the default footer scripts.目录锚点:#说明#参数#源码说明(Description)钩子名的动态部分,$GLOBALS['hook_suffix']引用当前页的全局钩子后缀。参数(Parameters)参数类...

日期:2020-09-02 17:44:20 浏览:1069

customize_save_{$this->id_data[‘base’]}

do_action( "customize_save_{$this->id_data[‘base’]}", WP_Customize_Setting $this )动作钩子::在调用WP_Customize_Setting::save()方法时激发。Action Hook: Fires when the WP_Customize_Setting::save() method is called.目录锚点:#说明#参数#源码说明(Description)钩子名称的动态部分,$this->id_data...

日期:2020-08-15 15:47:24 浏览:806

customize_value_{$this->id_data[‘base’]}

apply_filters( "customize_value_{$this->id_data[‘base’]}", mixed $default )过滤器::过滤未作为主题模式或选项处理的自定义设置值。Filter Hook: Filter a Customize setting value not handled as a theme_mod or option.目录锚点:#说明#参数#源码说明(Description)钩子名称的动态部分,$this->id_date['base'],指的是设置...

日期:2020-08-15 15:47:24 浏览:898

get_comment_author_url

过滤钩子:过滤评论作者的URL。Filter Hook: Filters the comment author’s URL.目录锚点:#源码源码(Source)更新版本源码位置使用被使用 wp-includes/comment-template.php:32610...

日期:2020-08-10 23:06:14 浏览:930

network_admin_edit_{$_GET[‘action’]}

do_action( "network_admin_edit_{$_GET[‘action’]}" )操作挂钩:启动请求的处理程序操作。Action Hook: Fires the requested handler action.目录锚点:#说明#源码说明(Description)钩子名称的动态部分$u GET['action']引用请求的操作的名称。源码(Source)更新版本源码位置使用被使用3.1.0 wp-admin/network/edit.php:3600...

日期:2020-08-02 09:56:09 浏览:876

network_sites_updated_message_{$_GET[‘updated’]}

apply_filters( "network_sites_updated_message_{$_GET[‘updated’]}", string $msg )筛选器挂钩:在网络管理中筛选特定的非默认站点更新消息。Filter Hook: Filters a specific, non-default site-updated message in the Network admin.目录锚点:#说明#参数#源码说明(Description)钩子名称的动态部分$_GET['updated']引用了非默认的...

日期:2020-08-02 09:56:03 浏览:863

pre_wp_is_site_initialized

过滤器::过滤在访问数据库之前是否初始化站点的检查。Filter Hook: Filters the check for whether a site is initialized before the database is accessed.目录锚点:#源码源码(Source)更新版本源码位置使用被使用 wp-includes/ms-site.php:93910...

日期:2020-07-29 10:15:38 浏览:833

WordPress 的SEO 教学:如何在网站中加入关键字(Meta Keywords)与Meta 描述(Meta Description)?

你想在WordPress 中添加关键字和meta 描述吗?关键字和meta 描述使你能够提高网站的SEO。在本文中,我们将向你展示如何在WordPress 中正确添加关键字和meta 描述。为什么要在WordPress 中添加关键字和Meta 描述?关键字和说明让搜寻引擎更了解您的帖子和页面的内容。关键词是人们寻找您发布的内容时,可能会搜索的重要词语或片语。而Meta Description则是对你的页面和文章的简要描述。如果你想要了解更多关于中继标签的资讯,可以参考Google的说明。Meta 关键字和描...

日期:2020-10-03 21:18:25 浏览:1717

谷歌的SEO是什么

SEO (Search Engine Optimization)中文是搜寻引擎最佳化,意思近于「关键字自然排序」、「网站排名优化」。简言之,SEO是以搜索引擎(如Google、Bing)为曝光媒体的行销手法。例如搜寻「wordpress教学」,会看到本站的「WordPress教学:12个课程…」排行Google第一:关键字:wordpress教学、wordpress课程…若搜寻「网站架设」,则会看到另一个网页排名第1:关键字:网站架设、架站…以上两个网页,每月从搜寻引擎导入自然流量,达2万4千:每月「有机搜...

日期:2020-10-30 17:23:57 浏览:1308