java - DynamoDb 正在存储值 1 而不是 boolean 值 true

标签 java database amazon-web-services boolean

我有一个方法,它只是为特定记录存储标志值 true。我的标志属性已定义为 boolean 值,在我的 DynamoDB 数据库中具有值 true/false。 在运行此方法时,它不是以某种方式存储真值,而是为标志属性插入一个新列作为数字数据类型,并写入值 1 而不是 true。在调试时我可以看到它读取的值是“真”,但在写我的猜测时它用 1 表示真,用 0 表示假,因此写 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;
   }

最佳答案

DynamoDb 默认将 boolean 值存储为 0 或 1。

使用以下装饰器将属性分别保存为 falsetrue

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

注意:用于执行此操作的@DynamoDBNativeBooleandeprecated

关于java - DynamoDb 正在存储值 1 而不是 boolean 值 true,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47446171/

相关文章:

java - 设置 fragment View

java - 将@Value注入(inject)到导入的第三个jar中的bean中

mysql - 只保留实体 id 而不是 Set<Entity> 来减少连接操作是个好主意吗

javascript - 用户名不能是电子邮件格式,因为用户池是为电子邮件配置的

java - 用于 Eclipse 的 Spring 上下文 XML validator ?

mysql - 已部署服务器上的 Grails 数据库迁移

python - SQLAlchemy:使用两个 MySQL 模式中的表进行查询

amazon-web-services - CloudWatch 警报不会因丢失数据而触发

amazon-web-services - 如何更改在 AWS 数据管道中运行的 Hive 事件的内存设置?

java - StaleObjectstateException 行被更新或删除