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

时间:2019-04-15 04:24:38

标签: java orm morphia

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

{ 
    "_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变量中的值,但是似乎没有任何效果。有什么办法可以实现?

1 个答案:

答案 0 :(得分:2)

查看Morphia LifeCycle事件:https://www.playframework.com/modules/morphia-1.2.4/lifecycle-def

@PostLoad在这里会有所帮助。您可能还需要@Transient