二、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会抛出异常。