AppSync 检查 DynamoDB 记录是否存在
创始人
2024-09-11 13:00:56
0

要检查 DynamoDB 中的记录是否存在,可以使用 AWS AppSync 和 AWS Lambda 来实现。下面是一个示例解决方案,其中包含了 AppSync 的 GraphQL 查询和 Lambda 函数的代码示例。

  1. 创建 DynamoDB 表 首先,在 AWS 控制台上创建一个 DynamoDB 表,表名为 "MyTable",并具有一个名为 "id" 的主键。

  2. 创建 GraphQL Schema 在 AppSync 控制台中,创建一个新的 GraphQL API,并定义一个包含名为 "checkRecordExists" 的查询的 GraphQL Schema。

type Query {
  checkRecordExists(id: ID!): Boolean!
}
  1. 创建 Lambda 函数 在 AWS Lambda 控制台中,创建一个新的 Lambda 函数,函数名称为 "checkRecordExistsLambda"。
import boto3

def lambda_handler(event, context):
    # 获取 DynamoDB 表名
    table_name = "MyTable"
    
    # 获取要检查的记录的 ID
    record_id = event['arguments']['id']
    
    # 创建 DynamoDB 客户端
    dynamodb = boto3.resource('dynamodb')
    table = dynamodb.Table(table_name)
    
    # 检查记录是否存在
    response = table.get_item(
        Key={
            'id': record_id
        }
    )
    
    # 返回记录是否存在的布尔值
    return 'Item' in response
  1. 配置 AppSync 数据源 在 AppSync 控制台中,选择你的 API,并在 "数据源" 部分创建一个新的 Lambda 数据源。将该数据源与步骤 3 中创建的 Lambda 函数关联。

  2. 配置 AppSync 解析器 在 AppSync 控制台中,选择你的 API,并在 "模式" 部分创建一个新的查询解析器。将该解析器与步骤 4 中创建的数据源关联,并使用以下 VTL 模板定义解析器的请求模板和响应模板:

请求模板:

{
  "version": "2017-02-28",
  "operation": "Invoke",
  "payload": {
    "id": $util.toJson($context.arguments.id)
  }
}

响应模板:

#if($ctx.result)
  true
#else
  false
#end
  1. 测试查询 在 AppSync 控制台的查询编辑器中,测试 "checkRecordExists" 查询。
query CheckRecordExists {
  checkRecordExists(id: "myRecordId")
}

以上就是使用 AppSync 检查 DynamoDB 记录是否存在的解决方法,其中包含了 AppSync 的 GraphQL 查询和 Lambda 函数的代码示例。您可以根据自己的需求进行适当的修改和扩展。

相关内容

热门资讯

玩家攻略推荐!吉祥填大坑有插件... 玩家攻略推荐!吉祥填大坑有插件吗,开心泉州小程序有挂吗(有挂开挂辅助安装)这是一款可以让一直输的玩家...
辅助透视!大唐辅助软件,aap... 辅助透视!大唐辅助软件,aapoker透视脚本下载-原生有挂开挂辅助器;打开点击测试直接进入微信(1...
重大消息!微信微乐挂有没有,广... 重大消息!微信微乐挂有没有,广西老友玩有破解吗(有挂开挂辅助工具);打开点击测试直接进入微信(136...
透明工具!掌心辅助插件,wpk... 透明工具!掌心辅助插件,wpk控制牌是真的吗-往昔有挂开挂辅助挂;打开点击测试直接进入微信(1367...
总算了解!决战卡五星辅助软件哪... 大家好,今天小编来为大家解答决战卡五星辅助软件哪个好用这个问题咨询软件客服可以免费测试直接加微信(1...
透明有挂!九九山城麻将辅助器,... 九九山城麻将辅助器是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我...
最新技巧!佛手在线做辅助下载,... 最新技巧!佛手在线做辅助下载,大菠萝免费辅助(有挂开挂辅助挂);无需打开直接搜索加(薇:136704...
透视辅助!指尖四川小程序破解器... 透视辅助!指尖四川小程序破解器,wepoker模拟器哪个-原先有挂开挂辅助平台;无需打开直接搜索薇:...
玩家科普!四川家园游戏辅助器平... 玩家科普!四川家园游戏辅助器平台交易,顺欣茶楼开挂(有挂开挂辅助神器);亲,四川家园游戏辅助器平台交...
透视透明!兴动游戏辅助,wep... 透视透明!兴动游戏辅助,wepoker看底牌-原先有挂开挂辅助下载1、下载安装好兴动游戏辅助,进入游...