

本文属于机器翻译版本。若本译文内容与英语原文存在差异，则一律以英文原文为准。

# 使用 AWS Glue 和 Athena 保持更新目标表中的数据
<a name="sample-keep-data-updated"></a>

本示例项目演示了如何使用 AWS Glue Catalog 查询目标表以获取当前数据，然后使用 Amazon Athena 从其他来源获取新数据进行更新。

在本项目中，Step Functions 状态机调用 AWS Glue Catalog 来验证 Amazon S3 存储桶中是否存在目标表。如果找不到表，它将创建一个新表。然后，Step Functions 将运行 Athena 查询，从不同的数据来源向目标表添加行：首先查询目标表以获取最近日期，然后查询源表以获取更多最新数据，并将其插入到目标表中。

## 第 1 步：创建状态机
<a name="sample-keep-data-updated-create"></a>

1. 打开 [Step Functions 控制台](https://console.aws.amazon.com/states/home?region=us-east-1#/)，然后选择**创建状态机**。

1. 选择**从模板创建**，然后找到相关的入门模板。选择**下一步**以继续。

1. 选择模板使用方式：

   1. **运行演示** — 创建只读状态机。审核后，您可以创建工作流和所有相关资源。

   1. **构建依据** — 提供可编辑的工作流定义，您可借助自有资源对其进行审核、定制并部署。（**不会**自动创建函数或队列等相关资源。）

1. 选择**使用模板**继续进行选择。
**注意**  
*部署到您的账户的服务将会收取标准费用。*

## 第 2 步：运行演示状态机
<a name="sample-keep-data-updated-start-execution"></a>

如果您选择了**运行演示**选项，则所有相关资源都将部署并准备好运行。如果您选择了**构建依据**选项，则可能需要先设置占位符值并创建其他资源，然后才能运行自定义工作流。

1. 选择**部署并运行**。

1. 等待 CloudFormation 堆栈部署。这一过程耗时最多 10 分钟。

1. 出现**开始执行**选项后，查看**输入**并选择**开始执行**。

**恭喜您！**  
现在，您应该有了一个正在运行的状态机演示。您可以在**图表视图**中选择状态来查看输入、输出、变量、定义和事件。