利用java代码给mongo数据库加索引、删除索引等操作

网上搜了一下相关代码,不是互相抄瞎写就是答非所问,只好自己摸索着写一下,修改之后那这篇文章记录一下,免得以后遗忘。
我是在springboot项目中创建了一个类,需要创建索引的时候,在Test里写个函数跑一边就可以了。

package com.sohu.umab.usercenter.service.impl;

import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.index.Index;
import org.springframework.data.mongodb.core.index.IndexInfo;
import org.springframework.stereotype.Repository;

import javax.annotation.Resource;
import java.util.List;
import java.util.Set;

/**
 * 给mongo数据库创建索引
 */
@Repository
public class CreateMongoIndex  {
    @Resource
    private MongoTemplate mongoTemplate;

    /**
     * 创建单个索引或者联合索引
     *
     * @param index_key 索引的名称,支持多个索引一起创建联合索引
     * @param collectionName 集合名称
     * @return
     */
    public boolean createInboxIndex(String collectionName, String... index_key) {
        boolean success = true;
        try {
            Index index = new Index();
            for (int i=0;i<index_key.length;i++){
                index.on(index_key[i],Sort.Direction.ASC);
            }
            mongoTemplate.indexOps(collectionName).ensureIndex(index);

        } catch (Exception ex) {
            success = false;
        }
        return success;
    }

    /**
     * 获取现有索引集合
     *
     * @return
     */
    public List<IndexInfo> getInboxIndex(String collectionName) {
        List<IndexInfo> indexInfoList = mongoTemplate.indexOps(collectionName).getIndexInfo();
        return indexInfoList;
    }

    /**
     * 删除索引
     *
     * @param indexName 索引的名称
     * @param collectionName 集合名称
     * @return
     */
    public boolean deleteInboxIndex(String indexName, String collectionName) {
        boolean success= true;
        try {
            mongoTemplate.indexOps(collectionName).dropIndex(indexName);
        } catch (Exception ex) {
            success= false;
        }
        return success;
    }

	/**
	* 获取mongo中数据集合的名称
	*/
    public Set<String> getNames(){
        Set<String> res = mongoTemplate.getCollectionNames();
        return res;
    }
  
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
首先,需要在 Java 代码中引入 MongoDBJava Driver 和 MongoDB 的注解包,例如: ``` import com.mongodb.MongoClient; import com.mongodb.MongoCredential; import com.mongodb.ServerAddress; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import org.bson.Document; import org.mongodb.morphia.Datastore; import org.mongodb.morphia.Morphia; import org.mongodb.morphia.annotations.Index; import org.mongodb.morphia.annotations.Indexes; import org.mongodb.morphia.mapping.Mapper; import org.mongodb.morphia.mapping.MapperOptions; import org.mongodb.morphia.mapping.codec.DocumentWriter; ``` 然后,在需要建立联合索引的实体类中添 `@Indexes` 注解,例如: ``` @Entity("users") @Indexes({ @Index(fields = @Field("username")), @Index(fields = {@Field("username"), @Field("email")}) }) public class User { @Id private ObjectId id; private String username; private String email; // ... } ``` 在上述代码中,`@Indexes` 注解用于定义一个或多个索引,`@Index` 注解用于定义单个索引。可以使用 `fields` 属性指定索引的字段,使用 `direction` 属性指定排序方式,使用 `name` 属性指定索引的名称,等等。 最后,使用 Morphia 框架提供的 `ensureIndexes()` 方法建立索引,例如: ``` Datastore datastore = morphia.createDatastore(mongoClient, "mydb"); datastore.ensureIndexes(); ``` 在上述代码中,`morphia` 是 Morphia 框架的实例,`mongoClient` 是 MongoDB 的客户端,`mydb` 是数据库名称。`ensureIndexes()` 方法用于建立实体类中定义的所有索引

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值