sql >> Databasteknik >  >> NoSQL >> MongoDB

Samlingsbaserad flerhyres i vårdata mongo

Du kan utöka MappingMongoEntityInformation för att åsidosätta getCollectionName(). Lagringsoperationerna anropar getCollectionName() för varje operation. Jag antar att tenantId skulle vara en ThreadLocal

public class TenantThreadLocal extends ThreadLocal<String> {
    private final static TenantThreadLocal instance = new TenantThreadLocal();

    public static TenantThreadLocal instance() {
        return instance;
    }
}

Och den åsidosatta klassen med konstruktörerna utelämnades.

public class TenantMappingMongoEntityInformation<T, ID extends java.io.Serializable>  extends MappingMongoEntityInformation<T, ID> {

    @Override
    public String getCollectionName() {
        return TenantThreadLocal.instance().get() + super.getCollectionName();
    }
}

Skapa sedan ditt arkiv:

MongoPersistentEntity<YourObject> persistentEntity = 
    (MongoPersistentEntity<YourObject>) 
    mongoOperations.getConverter()
    .getMappingContext()
    .getPersistentEntity(YourObject.class);

MongoEntityInformation<YourObject, ObjectId> mongoEntityInformation =
    new MappingMongoEntityInformation<YourObject, ObjectId>(persistentEntity);

CrudRepository<YourObject, ObjectId> repository =
    new SimpleMongoRepository<YourObject, ObjectId>(mongoEntityInformation, mongoOperations);



  1. Varför är Redis SET-prestanda bättre än GET?

  2. Spring MongoItemReader läser inte alla poster vid enstaka exekvering

  3. AttributeError:'tuple'-objektet har inget attribut 'insert'

  4. Returnera det senaste dokumentet från en uppslagning