开发者社区> JKXQJ> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

mongoDB导出数据库所有集合内容到json文件

简介: 网上搜了一圈,官方并有提供批量导出所有集合到json文件的方法。有不少脚本可以实现,但是我还是习惯用java,如下 package starcLL.
+关注继续查看

网上搜了一圈,官方并有提供批量导出所有集合到json文件的方法。有不少脚本可以实现,但是我还是习惯用java,如下

package starcLL.webClient;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.regex.Pattern;

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;

import org.bson.Document;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.mongodb.BasicDBObject;
import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.MongoException;
import com.mongodb.ServerAddress;
import com.mongodb.client.ListIndexesIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;

@Component
public class MongodbClient {

    private static String starcLL_mongodb_ip="填写你的ip";
    private static int starcLL_mongodb_port=填写你的端口;
    private static String starcLL_mongodb_name="填写你的数据库名"; 

    public static MongoClient mongoClient = null;
    public static MongoDatabase database = null;
    public static ServerAddress serverAddress = null;
    public static MongoCredential credentials = null;
    public static List<ServerAddress> addressLists = new ArrayList<ServerAddress>();
    public static List<MongoCredential> credentialsLists = new ArrayList<MongoCredential>();

    public static MongoClient getMongoClient() {
        if (null == mongoClient) {
            try {
                serverAddress = new ServerAddress(starcLL_mongodb_ip, starcLL_mongodb_port);
                addressLists.add(serverAddress);
                credentials = MongoCredential.createCredential("数据库", "用户名","密码".toCharArray());
                credentialsLists.add(credentials);
                return new MongoClient(addressLists,credentialsLists);
            } catch (MongoException e) {
                System.out.println(e.toString());
            }
        }
        return mongoClient;
    }



    public static void main(String[] args) throws IOException {
        MongoClient mongoClient=getMongoClient();
        Set<String> collectionNames=mongoClient.getDB(starcLL_mongodb_name).getCollectionNames();
        MongoDatabase mongoDatabase=mongoClient.getDatabase(starcLL_mongodb_name);
        System.out.println("开始...");

        int i=collectionNames.size();
        for (String cName:collectionNames) {
            JSONArray jsonArray=new JSONArray();
               System.out.println("获取集合:"+cName);
               MongoCursor<Document> cursor = mongoDatabase.getCollection(cName).find().iterator();
            try {
                while (cursor.hasNext()) {
                    jsonArray.add(cursor.next().toJson());
                }
            } finally {
                cursor.close();
            }
            File txt=new File("C:/Users/Administrator/Desktop/svc/"+i+".json");
            if(!txt.exists()){
               txt.createNewFile();
            }
            byte bytes[]=new byte[512];
            bytes=jsonArray.toString().getBytes();    
            int b=jsonArray.toString().length();    
            FileOutputStream fos=new FileOutputStream(txt);
            fos.write(bytes,0,b);
            fos.close();
            i--;
        }

    }
}

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
泛型-JSON串转集合
用于提取参数中的list,也可方法中直接调用parseArray
0 0
使用jackson的@JsonProperty()进行字段修改成自己想要的,并实现json字符串和list集合相互转换
使用jackson的@JsonProperty()进行字段修改成自己想要的,并实现json字符串和list集合相互转换
0 0
泛型-JSON串转集合
用于提取参数中的list,也可方法中直接调用parseArray
0 0
SpringMVC - 数据绑定(基本数据、包装类、数组、对象、集合:List、Set、Map、Json)(一)
SpringMVC - 数据绑定(基本数据、包装类、数组、对象、集合:List、Set、Map、Json)(一)
0 0
Java之JSON字符串与List集合之间相互转换
Java之JSON字符串与List集合之间相互转换
0 0
【Groovy】json 字符串反序列化 ( 使用 JsonSlurper 进行 json 字符串反序列化 | 根据 map 集合构造相关类 )
【Groovy】json 字符串反序列化 ( 使用 JsonSlurper 进行 json 字符串反序列化 | 根据 map 集合构造相关类 )
0 0
Java对象或集合数据与JSON格式数据之间的转换
对比主流JSON库,熟悉FastJson应用场景
0 0
【js jQuery】map集合 循环迭代取值---以及 map、json对象、list、array循环迭代的方法和区别
后台给前台传来一个map    @ResponseBody @RequestMapping(value = "getSys") public Map getSys(){ Map map = orderService.
1064 0
+关注
JKXQJ
好好学习,天天向上
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Data as a Service - 数据即服务 -- MongoDB⾼级应⽤模式
立即下载
PostgresChina2018_张启程_为什么我们抛弃MongoDB和MySQL,选择PgSQL
立即下载
阿里云MongoDB备份恢复功能说明和原理介绍
立即下载