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