1.@Id
主键,不可重复,自带索引,可以在定义的列名上标注,需要自己生成并维护不重复的约束。如果自己不设置@Id主键,mongo会自动生成一个唯一主键,并且插入时效率远高于自己设置主键。原因可参考上一篇mongo和mysql的性能对比。
在实际业务中不建议自己设置主键,应交给mongo自己生成,自己可以设置一个业务id,如int型字段,用自己设置的业务id来维护相关联的表。
2.@Indexed
声明该字段需要加索引,加索引后以该字段为条件检索将大大提高速度。
唯一索引的话是@Indexed(unique = true)。
也可以对数组进行索引,如果被索引的列是数组时,MongoDB会索引这个数组中的每一个元素。
也可以对整个Document进行索引,排序是预定义的按插入BSON数据的先后升序排列。
也可以对关联的对象的字段进行索引,譬如User对关联的address.city进行索引。
3.@Document
标注在实体类上,类似于hibernate的entity注解,标明由mongo来维护该表。
@Data
@Document(collection = "hsp_set_meal_update")
public class SetMealUpdate {
@Id
private String id;
private String code;
@Field("hsp_code")
private String hspCode;
/***/
@Field("hsp_name")
private String hspName;
/***/
@Field("hsp_cooperation_type")
private String hspCooperationType;
/***/
@Field("file_code")
private String fileCode;
/***/
@Field("file_name")
private String fileName;
private String status;
/***/
@Field("created_at")
private String createdAt;
/***/
@Field("updated_at")
private String updatedAt;
/***/
private String remark;
/**
* 处理人:系统用户
*/
private String handler;
}
4.@CompoundIndex
复合索引,加复合索引后通过复合索引字段查询将大大提高速度。
@Document
@CompoundIndexes({
@CompoundIndex(name = "age_idx", def = "{'lastName': 1, 'age': -1}")
})
public class Person<T extends Address> {
}
5.@Field
代表一个字段,可以不加,不加的话默认以参数名为列名。
给映射存储到 mongodb 的字段取别名
在 java bean 中字段名为 firstName,存储到 mongo 中 key 为 fName
@Field("fName")
private String firstName;
6.@Transient
被该注解标注的,将不会被录入到数据库中。只作为普通的javaBean属性。
版权声明:本文为qq_43533700原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。