morphia(1)-基础

本文详细介绍了如何使用Morphia框架在Java应用中与MongoDB进行实体映射,包括@Embedded、@Id、@Reference等注解的使用,以及如何创建索引和指定文档名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

二、Mapping classes

entity类上加注解:@Entity,其成员变量必须有@Id

@Id
private ObjectId id;

其在mongodb中变量名: _id

@Embedded,标示子类(子文档),用了@Embedded,@Id可以不存在。

例子:

import org.bson.types.ObjectId;
import org.mongodb.morphia.annotations.Entity;
import org.mongodb.morphia.annotations.Field;
import org.mongodb.morphia.annotations.Id;
import org.mongodb.morphia.annotations.Index;
import org.mongodb.morphia.annotations.Indexes;
import org.mongodb.morphia.annotations.Property;
import org.mongodb.morphia.annotations.Reference;

@Entity("employees")
@Indexes(
    @Index(fields=@Field(value="salary",type=IndexType.ASC))
)
public class Employee {
    @Id
    private ObjectId id;
    private String name;
    @Reference
    private Employee manager;
    @Reference
    private List<Employee> directReports;
    @Property("wage")
    private Double salary;
}

@Entity("employees"):标示mongodb中文档名为:employees。如果不指定employees,则默认类名作为文档名。

@Indexes:标示为salary建立“升序”索引。

@Id:主键id,类型是ObjectId。注意:该id可以是任何类型,不见得就是ObjectId。除了transient和static字段,Morphia视图去保存任何没有被注解的字段

@Property:该注解可选。如果不指定则使用该java属性名作为文档字段名。

@Reference:引用其他实体。形如:

"books" : [ 
        {
            "$ref" : "books",
            "$id" : ObjectId("5bceb691dd007127d4271799")
        }
    ]

注意,这些引用实体必须提前已经被保存了或者至少分配了Id,否则morphia会抛出异常。

 

转载于:https://www.cnblogs.com/yaoyuan2/p/9836884.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值