准备:springboot 项目, mongodb,navicat工具
项目映入jar包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency>
1.mongodb集合和java对象映射
import lombok.Data;
import org.springframework.data.mongodb.core.index.Indexed;
import org.springframework.data.mongodb.core.mapping.Document;
/**
* @description:
* @Author : lockie
* @Date : 2021/10/27
*/
@Data
@Document(collection = "user_document_test")
public class UserDocument extends BaseDocument{
private String id;
private String userName;
private Integer age;
@Indexed
private Integer status;
@Field("address")
private String address;
private Integer sex;
private String phone;
private String email;
private Integer pageNum = 1;
private Integer pageSize = 10;
}
@Id
主键,不可重复,自带索引,可以在定义的列名上标注,需要自己生成并维护不重复的约束。如果自己不设置@Id主键,mongo会自动生成一个唯一主键,并且插入时效率远高于自己设置主键。原因可参考上一篇mongo和mysql的性能对比。
在实际业务中不建议自己设置主键,应交给mongo自己生成,自己可以设置一个业务id,如int型字段,用自己设置的业务id来维护相关联的表。我这里设置了id字段,但是我并没有使用,还是用的mongodb生成的id,对应字段是_id
@Document
标注在实体类上,类似于hibernate的entity注解,标明由mongo来维护该表。注意:这里有个容易犯错的地方 @Document里面集合单词是 collection 而不是 collation
@Indexed
声明该字段需要加索引,加索引后以该字段为条件检索将大大提高速度。
唯一索引的话是@Indexed(unique = true)。
也可以对数组进行索引,如果被索引的列是数组时,MongoDB会索引这个数组中的每一个元素。
也可以对整个Document进行索引,排序是预定义的按插入BSON数据的先后升序排列。
也可以对关联的对象的字段进行索引,譬如User对关联的address.city进行索引。(注解怎么写还不清楚,待查)@Field
代表一个字段,可以不加,不加的话默认以参数名为列名。
import cn.hutool.core.date.DateUtil;
import lombok.Data;
import java.util.Date;
@Data
public class BaseDocument {
/**
* 创建人
*/