DynamoDBMapper和DynamoDB表中的Table有什么区别?

5
在AWS DynamoDB中,有两种选项可用于对表执行CRUD操作。 DynamoDBMappercom.amazonaws.services.dynamodbv2.datamodeling.DynamoDBMapper;
    AmazonDynamoDB dbClient = AmazonDynamoDBAsyncClientBuilder.standard().withCredentials(creds)
            .withRegion("us-east-1").build();
    // creds is AWSCredentialsProvider

    DynamoDBMapper mapper = new DynamoDBMapper(dbClient);
    mapper.save(item);

数据表:com.amazonaws.services.dynamodbv2.document.Table;

static DynamoDB dynamoDB =new DynamoDB(dbClient);
Table table = dynamoDB.getTable("TABLE_NAME");
Item item =new Item().withPrimaryKey("","")
        .withString("":, "");
table.putItem(item);

这两者似乎执行相同的操作。

DynamoDBMapper是基于Table的一层抽象吗?如果是,那么使用每个的区别是什么?

1个回答

5
如果您想将Java类映射到DynamoDB表(这是一个有用的功能),请考虑远离旧的V1 API(com.amazonaws.services.dynamodbv2是V1)。V2软件包为software.amazon.awssdk.services.dynamodb.*。

使用DynamoDB V2增强客户端替换此旧API。您可以在此处了解更多信息:

在DynamoDB表中映射项

您可以在此处找到使用增强客户端的代码示例

以下是一个Java V2代码示例,向您展示如何使用增强客户端将数据放入Customer表中。正如您所看到的,您可以将Java类映射到DynamoDB表中的列,然后在向表中添加数据时创建一个Customer对象。

package com.example.dynamodb;


import software.amazon.awssdk.enhanced.dynamodb.DynamoDbEnhancedClient;
import software.amazon.awssdk.enhanced.dynamodb.DynamoDbTable;
import software.amazon.awssdk.enhanced.dynamodb.TableSchema;
import software.amazon.awssdk.enhanced.dynamodb.mapper.annotations.DynamoDbSortKey;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.dynamodb.DynamoDbClient;
import software.amazon.awssdk.services.dynamodb.model.DynamoDbException;
import software.amazon.awssdk.enhanced.dynamodb.mapper.annotations.DynamoDbBean;
import software.amazon.awssdk.enhanced.dynamodb.mapper.annotations.DynamoDbPartitionKey;
import java.time.Instant;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.ZoneOffset;


/*
 * Prior to running this code example, create an Amazon DynamoDB table named Customer with a key named id and populate it with data.
 * Also, ensure that you have setup your development environment, including your credentials.
 *
 * For information, see this documentation topic:
 *
 * https://docs.aws.amazon.com/sdk-for-java/latest/developer-guide/get-started.html
 */
public class EnhancedPutItem {

    public static void main(String[] args) {

        Region region = Region.US_EAST_1;
        DynamoDbClient ddb = DynamoDbClient.builder()
                .region(region)
                .build();

        DynamoDbEnhancedClient enhancedClient = DynamoDbEnhancedClient.builder()
                .dynamoDbClient(ddb)
                .build();

        putRecord(enhancedClient) ;
        ddb.close();
    }

    
    // Puts an item into a DynamoDB table
    public static void putRecord(DynamoDbEnhancedClient enhancedClient) {

        try {
            DynamoDbTable<Customer> custTable = enhancedClient.table("Customer", TableSchema.fromBean(Customer.class));

            // Create an Instant
            LocalDate localDate = LocalDate.parse("2020-04-07");
            LocalDateTime localDateTime = localDate.atStartOfDay();
            Instant instant = localDateTime.toInstant(ZoneOffset.UTC);

            // Populate the Table
            Customer custRecord = new Customer();
            custRecord.setCustName("Susan Blue");
            custRecord.setId("id103");
            custRecord.setEmail("sblue@noserver.com");
            custRecord.setRegistrationDate(instant) ;

            // Put the customer data into a DynamoDB table
            custTable.putItem(custRecord);

        } catch (DynamoDbException e) {
            System.err.println(e.getMessage());
            System.exit(1);
        }
        System.out.println("done");
    }


    @DynamoDbBean
    public static class Customer {

        private String id;
        private String name;
        private String email;
        private Instant regDate;

        @DynamoDbPartitionKey
        public String getId() {
            return this.id;
        };

        public void setId(String id) {

            this.id = id;
        }

        @DynamoDbSortKey
        public String getCustName() {
            return this.name;

        }

        public void setCustName(String name) {

            this.name = name;
        }

        public String getEmail() {
            return this.email;
        }

        public void setEmail(String email) {

            this.email = email;
        }

        public Instant getRegistrationDate() {
            return regDate;
        }
        public void setRegistrationDate(Instant registrationDate) {

            this.regDate = registrationDate;
        }
    }
    
}

1
好的,我明白我应该使用最新版本的包。但问题仍然存在。DynamoDBMapper还是Table,为什么? - Lenzman
1
这就是我喜欢在这个开发社区中帮助的方式。让社区了解最新的AWS SDK for Java V2。使用V2是最佳实践。所有V2中的代码都经过了大量测试并且可靠。谢谢! - smac2020
2
但问题是,对于名称“dynamodbv2”,大多数人会认为它是第二版。 - Lenzman
2
同意 - 这很令人困惑,已经向SDK团队提出了。 - smac2020
4
提示:所有 V2 包都以 "software.amazon.awssdk" 开头。 - smac2020
显示剩余2条评论

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接