DyanmoDb 正在存储值 1 而不是布尔值 true

我有一个方法,它只是为特定记录存储标志值true。我的标志属性已定义为布尔值,在我的 DynamoDB 数据库中具有值 true/false。在运行此方法时,它以某种方式不是存储 true 值,而是为 flag 属性插入一个新列作为数字数据类型,并将值 1 而不是 true 写入。在调试时,我可以看到它正在将值读取为“true”,但在编写时,我的猜测是它采用1表示true,0表示false,因此编写1。

public static ArrayList<UserWishListBuks> removeNotification(int Statusid) {
    AmazonDynamoDBClient ddb = NavigationDrawerActivity.clientManager
            .ddb();
    DynamoDBMapper mapper = new DynamoDBMapper(ddb);
    DynamoDBScanExpression scanExpression = new DynamoDBScanExpression();
    Boolean value = true;
    try{
        PaginatedScanList<UserWishListBuks> result = mapper.scan(
                UserWishListBuks.class, scanExpression);
        for (UserWishListBuks bre : result) {
            if( (bre.getBOOK_STATUS_ID()==(Statusid))   )
            {
                bre.setNOTIFICATION_FLAG(true);
                mapper.save(bre);
            }
        }
    }catch (AmazonServiceException ex) {
        NavigationDrawerActivity.clientManager
                .wipeCredentialsOnAuthError(ex);
    }
    return null;
   }

答案 1

默认情况下,DynamoDb 会将布尔值存储为 0 或 1。

使用以下修饰器将属性分别另存为 或 保存。falsetrue

@DynamoDBTyped(DynamoDBAttributeType.BOOL)
@DynamoDBAttribute
private boolean notificationFlag;

注意:用于执行此操作的已弃用@DynamoDBNativeBoolean


答案 2

这是意料之中的,看看dynamodb的数据类型文档:http://docs.aws.amazon.com/amazondynamodb/latest/developerguide/DynamoDBMapper.DataTypes.html

Java 类型的布尔值将存储为 dynamodb、0 或 1 中的数字类型。或者,您可以使用 将 Java 映射到 DynamoDB 数据类型@DynamoDBNativeBooleanTypeBooleanBOOL


推荐