Mongodb 的ORM 框架Morphia 技术POJO 类注解详解 1、@Entity 如果你想通过 Morphia 把你的对象保存到 Mongo 中,你首先要做的是使用@Entity 注解你的类: importcom.google.code.morphia.annotations.Entity; @Entity public class Hotel { ... } A、名称和构造方法 你可以为你的MongoDBDBConllection 设置名称。必须有一个无参的默认构造方法。 @Entity("hotels") public class Hotel { ... public Hotel() { } ... } 注意:你的默认构造方法不一定是 public,也可以是 protected 或 private。 B、在文档中的类名和怎样废弃使用类名 在@Entity 注解中提供了一个可选的参数用来标识是否在文档中保存类名。 @Entity(value="hotels", noClassnameStored=true) public class Hotel { ... public Hotel() { } ... } 默认会在文档中保存类名。 为什么要使用他哪?保存类名的主要目的是,当你在同一个链接中保存不同的实体对象,但是你想作为他们的基类或超类来读取。 如: @Entity("animals") abstract class Animal { String name; } @Entity("animals") Cat extends Animal { ... } @Entity("animals") Dog extends Animal { ... } //And then performing the following query... List
animals = ds.createQuery(Animal.class).asList(); 正如你看到的,如果不在文档中保存类名,Morphia 将不能正确的识别创建那个类。 如果你在一个链接中只保存唯一的实体类型并且你还关心你的数据库大小,在你的@Entity 注解上加上noClassnameStored=true 参数将会是安全的。 2、@Id 被@Entity 注解的类必须有一个唯一的 @Id 值;这些值被保存在MongoDB 数据库的“id”属性中,这是一个必须的位索引。像在Hotel 类中: @Entity public class Hotel{ @Id privateObjectId id; ..... } 如上所示:被@Id 注解的ID 是ObjectId 类型的,这样,你就不用担心Id 的生成问题了,Mongo 会自动为你生成一个唯一的新的ObjectId 对象(就像 MySQL 中的auto_increment 类型的ID)。如果你想使用其他的类型作为ID,那么在你保存数据时就必须手动为ID 赋值。 3、@Indexed 此注解是为某个字段申请一个索引。当datastore.ensureIndexes() 方法被调用时这些索引就会被申请.. 更多如下: 把@Indexed 注解在你想让 MongoDB 创建索引的属性上...