百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

使用 Python 在 DynamoDB 上执行操作

qiyuwang 2025-03-26 16:32 5 浏览 0 评论

如何使用 Python 和 Boto3 库在 AWS DynamoDB 中创建表、加载数据、执行操作和查询/扫描表。

Amazon DynamoDB (DDB) 是一个 NoSQL 无服务器数据库。这意味着它是一个键值数据库,可提供灵活的模式,并可轻松扩展大量数据和高用户负载,并可用于按用量付费的定价规模。

在本文中,我们将了解如何使用 Python 和 Boto3 库在 AWS DynamoDB 中创建表、加载数据、执行操作和查询/扫描表。

为此,我将使用 Cloud9 作为我的 IDE,您可以选择使用您喜欢的任何 IDE,我选择使用 Cloud9。


创建表

我决定创建一个表,命名为:“生日”。该表将具有以下属性:人名、出生年份、月份和月份中的某天。

在分配分区和排序键时,我最初选择使用属性名称和年份。但是,后来在尝试查询我的表时发现,这两个词都在您不允许用作 DynamoDB 中的属性的保留词列表中。我将分区键更改为 Person 并将排序键更改为 Birthyear 并且能够避免任何问题。

注意在建表的时候,我们只添加了分区和排序键属性,剩下的属性我们会在加载数据到表的时候添加。

这是我的代码的要点:

import boto3

dynamodb = boto3.resource('dynamodb', region_name='us-east-1')

table = dynamodb.create_table(
    TableName='Birthdays',
    KeySchema=[
        {
            'AttributeName': 'Person',
            'KeyType': 'HASH'  #Partition key
        },
        {
            'AttributeName': 'Birthyear',
            'KeyType': 'RANGE'  #Sort key
        }
    ],
    AttributeDefinitions=[
        {
            'AttributeName': 'Person',
            'AttributeType': 'S'
        },
        {
            'AttributeName': 'Birthyear',
            'AttributeType': 'N'
        },
    ],
     ProvisionedThroughput={
        'ReadCapacityUnits': 10,
        'WriteCapacityUnits': 10
    }
)

要运行我提供的任何程序,请使用 Cloud9 中的终端并运行以下命令,Python 后跟文件名。 确保您在当前工作目录中并使用您的文件名。

python Week15_create_table.py

如果您已正确编写所有内容,您应该会看到:


加载表中的数据

创建表后,您最可能想要做的下一件事就是加载数据。 这也是我们将添加您希望包含在表中的任何其他属性的地方。 首先,您需要创建一个单独的 .json 文件来包含您的数据。

您将重复上面的脚本来添加尽可能多的数据。 为方便起见,请将 .json 文件保存在与 Python 脚本相同的工作目录中。

要加载数据,您可以运行以下脚本,请注意第 8 行它调用您创建的 .json 文件:

这是我的代码的要点:

import boto3
import json

dynamodb = boto3.resource('dynamodb', region_name='us-east-1')

table = dynamodb.Table('Birthdays')

with open("Birthday_data.json") as json_file:
    Birthdays = json.load(json_file)
    for Birthday in Birthdays:
        Person = Birthday['Person'] 
        Birthyear = int(Birthday['Birthyear'])
        info = Birthday['info']

        print("Adding person:", Person, Birthyear)

        table.put_item(
           Item={
               'Person': Person,
               'Birthyear': Birthyear,
               'info': info,
            }
        )

运行脚本时,它将打印出分区并对加载的每个项目的键进行排序。

从表中删除项目

要从表中删除项目,您需要知道要删除它的时间的分区和排序键:

这是代码的要点:

import boto3

client = boto3.client('dynamodb', region_name='us-east-1')

response = client.delete_item(
    TableName='Birthdays',
    Key={'Person': {'S': 'Dennis #########'}, 'Birthyear': {'N': '1970'}, 
    }
)


扫描表格

要扫描您的表,您只需要知道您的表的名称:

这是代码的要点:

import boto3

client = boto3.client('dynamodb', region_name='us-east-1')

response = client.scan(TableName='Birthdays')

print(response)

当您扫描表时,它将如下所示:

要查询您的表:

为了查询您的表格,在我的例子中,我正在寻找一个特定人的出生年份,我运行了以下代码:

这是代码的要点:

import boto3
from boto3.dynamodb.conditions import Key

client = boto3.client('dynamodb', region_name='us-east-1')

response = client.query(
    TableName='Birthdays',
    ExpressionAttributeValues={
        ':ident':{
            'S': 'Amy ######',
        },
    },
    KeyConditionExpression='Person = :ident',
    ProjectionExpression='Birthyear'
)

print(response['Items'])

程序的结果:

要删除您的表:

现在要删除您的表,您只需要表的名称:

这是我的代码的要点:

import boto3

dynamodb = boto3.resource('dynamodb', region_name='us-east-1')

table = dynamodb.Table('Birthdays')

table.delete()

您可以调整上述代码以满足您选择的表格。 重要的是要注意不能用作属性的保留字列表,因为它可能会在您开始尝试查询数据时给您带来问题。

相关推荐

微软宣布将于10月份关闭OneDrive组功能

【巴士数码】微软已经宣布将在今年10月关闭OneDrive的组功能。一年多之前,微软已经关闭了用户在OneDrive当中创建组的功能。大大多数用户会发现共享文件夹是一种合适的替代品,而且由于这一点,O...

玩转Win10任务栏:从基础设置到效率神器的全攻略

一、基础操作:解锁任务栏的「隐藏布局」...

文档以只读模式打开的原因及解决方法

当文档以只读模式打开时,可能由多种原因导致。以下是详细的原因分析与对应解决方法,您可根据实际情况灵活选择操作。一、文件属性设置问题(一)Windows系统在Windows系统中,若文件属性被标记...

Windows系统的优化(windows优化设置)

今天给大家讲一讲系统的图标和一些基本的优化。安装了原版系统之后有很多地方需要优化比如桌面图标小箭头,盾牌,休眠占用内存,关闭通知栏。首先我们打开软件这款软件以前就讲到过就是dism++软件,他可以清理...

Win 10偷偷传送用户隐私至微软(win10设备隐私)

自推出以来Win10不断被揭发盗取用户带宽、泄漏WiFi密码等各式各样的私隐问题,令不少网络专家开始留意Win10还隐藏了多少类似的私隐漏洞。最近再有人发现Win10部分功能静静...

OneDrive逆势下调存储空间,不限量存储被取消

日前,微软在周一晚发布的博客文章中表示,由于部分用户存滥用储存功能,所以该公司将取消不限量OneDrive存储服务。不限量用户的最大存储空间将被下调至1TB,定价为6.99美元,对于已存储较多文件和内...

Win10中那些被微软取消的功能(微软公司从9日起停止对windows8的主流服务支持)

很多用户在使用Win10的时候,都会发现一些在Win7系统中的功能被取消了,有的时候想找也找不到。那么到底是那些过去的功能在Win10中被取消了呢?下面我们就简单梳理一下,并且告诉大家解决的办法。Wi...

微软推Win11 Dev 26200.5570预览版:语音打字上线脏话过滤选项

IT之家4月26日消息,微软公司昨日(4月25日)发布博文,邀请Dev频道的WindowsInsider项目成员,测试适用于Windows1124H2的KB50556...

微软VSCode商店发现9款挖矿恶意插件,已安装超30万次

IT之家4月8日消息,科技媒体bleepingcomputer昨日(4月7日)发布博文,报道称安全专家在微软VSCode扩展商店中,发现了9款伪装成开发工具的恶意插件。这些插...

微软Windows 11开始菜单大改版!(windows 11 开始菜单)

根据最新消息,微软正在对Windows11的开始菜单进行重大改版,这一更新将彻底改变其布局和功能。Windows11的开始菜单将从现有的多栏布局改为单栏可滚动视图,所有固定图标和已安装应用都将集中...

OneDrive无限存储空间取消 免费降至5GB

2015-11-0313:35:06作者:徐鹏北京时间11月3日消息,微软在一篇博客文章中称,将取消OneDrive存储服务的不限量空间,原因是部分用户有滥用问题。OneDrive无限存储空间取消...

省出电脑C盘空间!微软悄悄更新:OneDrive终于能卸载了

快科技3月12日消息,近日,微软悄悄地在官方更新了关闭、禁用、卸载Windows自带软件OneDrive的方法。微软Windows系统自带了很多软件和功能,其中有很多我们可能永远都用不上。但这些软件还...

微软关闭OneDrive新建组群功能(windows关闭onedrive)

微软的OneDrive云端储存服务能够让你创建组群(Group),这样当你和团队成员共同从事一个项目的时候能够通过云端协作提升效率,并且组群的文档储存空间还将同你标准的OneDrive分割独立开来。不...

微软为何取消OneDrive无限制容量存储?被75TB占用吓坏

那么为什么微软会取消Office365的无限OneDrive存储呢?“自推出Office365订阅无限制存储服务以来,一小部分用户开始备份多台PC设备,存储众多电影收藏合集和DVR录像。在某些情况下...

Win11必关的5个设置!关闭后电脑流畅到起飞,操作简单不藏私!

Windows11虽然界面炫酷,但默认设置中隐藏了不少“拖慢电脑”的坑!尤其是老电脑用户,用久了卡顿、开机慢、反应迟钝……其实只需关闭几个鸡肋功能,就能让电脑提速50%以上!...

取消回复欢迎 发表评论: