📜  DynamboDB –表,项目和属性(1)

📅  最后修改于: 2023-12-03 14:40:54.450000             🧑  作者: Mango

DynamoDB –表,项目和属性

什么是DynamoDB?

DynamoDB是亚马逊AWS提供的一种NoSQL数据库,被设计用于处理大规模、低延迟的事务数据。它采用了高度强化的密钥-值数据模型,并具有快速的读写能力,而且能够横向扩展以适应需要不断增长的数据。

DynamoDB中的数据被组织成表,每个表由多个项(例如行)组成。表有一个主键,它是用来唯一标识表中每个项的属性。主键可以是标量值或复合值。

在创建DynamoDB表时,你需要指定表的主键。主键分为分区键和排序键。对于数据分散较宽的应用程序,需要选用相应的分区键以使得查询更快。

以下是一个DynamoDB表定义的例子:

| RowID | Column1 | Column2 | Column3 |
|-------|---------|--------|--------|
| 1 | value1 | value2 | value3 |
| 2 | value4 | value5 | value6 |
项目

DynamoDB表中的项又被称为项目。每个项目都有一个唯一的主键,可以通过该键访问该项目。主键以分区键和可选的排序键组成。排序键可以用于对表中的数据进行排序。项目可以包含零个或多个属性,每个属性都有一个名称和一个值。

以下是一个DynamoDB项目定义的例子:

{
    "RowID": {
        "N": "1"
    },
    "Column1": {
        "S": "value1"
    },
    "Column2": {
        "S": "value2"
    },
    "Column3": {
        "S": "value3"
    }
}
属性

DynamoDB中的每个项目可以包含任意数量的属性。属性只是由属性名和属性值组成的键值对。属性值可以是标量(如数字、字符串、布尔值等)或复杂数据类型(如嵌套的映射和列表)。

以下是一个DynamoDB属性定义的例子:

{
    "S": "value1"
}

在DynamoDB中有多种不同的属性类型,包括字符串、数字、二进制、布尔值、列表、集合和嵌套的映射。每种类型都有不同的表示方式和支持的操作。

总结一下,DynamoDB是一种支持高度扩展和低延迟事务处理的NoSQL数据库。它的数据被组织成表,每个表由项目组成,每个项目由多个属性组成。熟练掌握这些概念对于在DynamoDB上构建高效的应用程序非常重要。