猿问

使用 Morphia 从 Mongo 获取文档时将值设置为非 DB 属性

product这是MongoDB 中称为集合(表)的一个示例文档(行) :


    "_id" : ObjectId("5cb39171528a28f831f"), 

    "seller" : "Product Seller 1", 

    "title" : "Product Title 1", 

    "price" : "159.75", 

    "brand" : "Product Brand 1", 

    "productId" : NumberInt(247)

}

该集合的 Java 模型如下所示:


@Entity(value = "product", noClassnameStored = true)

@Data

public class Product {

    @Id

    @Property("_id")

    private ObjectId objectId;


    private String seller;

    private String title;

    private String price;

    private String brand;

    private Long productId;

}

我在这里使用 Morphia 作为 MongoDB Java 驱动程序。我正在使用 Lombok @Data 注释,它提供了构造函数、getter 和 setter。

该模型运行良好,能够从数据库中获取数据。我的新要求是在模型中添加一个附加字段。新字段的名称将是stringObjectId,它将存储objectId字符串格式的值。


请注意,数据库文档不会有任何更改。也就是说,没有新字段被添加到数据库文档中。


我希望当我以列表或单行的形式从集合中获取数据时, 也应该填充query.asList();

其中的值。stringObjectId像这样的东西:

stringObjectId = objectId.toString()


到目前为止,我已经尝试覆盖该模型的设置器和构造器来设置stringObjectId变量中的值,但似乎没有任何效果。有什么办法可以实现吗?

芜湖不芜
浏览 85回答 1
1回答

偶然的你

查看 Morphia LifeCycle 事件:https ://www.playframework.com/modules/morphia-1.2.4/lifecycle-def一个在这里@PostLoad会有所帮助。你可能也需要@Transient。
随时随地看视频慕课网APP

相关分类

Java
我要回答