问题:mongoBD在写入数据之后系统会自动生成的12字节唯一标识作为ID,即相当于mysql的主键ID,这里想使用自增的数值来作为ID,但是mongo并不支持
解决:需要ID数值自增,则基本上需要自己控制累加操作,可以借助redis生成唯一ID,redis本身单线程也有原子操作,保证ID唯不重复。这里既然已经接入了mongo,并且mongo也有原子操作,完全可以支持ID自增,直接使用mongo省时省力。
解决逻辑:关注方法findAndModify,这方法本身是原子操作,并且提供了设置项
// 是否返修改后的数据
private boolean returnNew;
//假如不存在是否插入新数据
private boolean upsert;
这两个可以保证,每一次操作都会有最新的ID返回,
所以在这里只需要新建一个collection来维护其他collection的ID,在这里collection中每一条记录中字段(自增的ID,collection名称)。这样就能直接维护起来ID随时可以取用。
下面考虑ID设置的问题,找到类AbstractMongoEventListener,看下源码就知道实现了 ApplicationListener 接口,并且这里面维护了很多事件响应,只要找到在生成数据的时候或者之前修改设置我们需要的ID就可以达到我们的目的,并且事件响应也不需要空考虑有的修改不到。
为了灵活控制某些文档需要使用自己的id有写不需要,这个时候可以使用注解达成来控制。
新建注解:
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* 用于Mongo生成自增ID注解
*
* @author hsf
* @since 2020/3/19
**/
@Retention(RetentionPolicy.RUNTIME)
@Target({
ElementType.FIELD})
public @interface AutoIncId {
}
新建一个维护ID的entity
import lombok.Data;
import org.bson.types.ObjectId;
import org.springframework.data