前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mongoexport导出数据时遇到的种种问题(好坑)

mongoexport导出数据时遇到的种种问题(好坑)

作者头像
双愚
发布2018-05-28 14:44:29
6.6K0
发布2018-05-28 14:44:29
举报

想导出mongodb数据库里的数据,结果,搞了一天,踩了无数的坑,才终于导出数据,真的,要哭了,赶紧记录下来(说实话,网上有些文章真的随着版本的更新,有些过时了,真的是助我踩坑耶) 我主要讲我踩得坑哈,顺便说下!

首先要开启服务,进入命令框 NET START MongoDB 然后进入安装目录(我的安装目录):cd D:\Program Files\Work\MongoDB\Server\3.4\bin,执行 mongo

执行以上两步后,就可以输入有用的命令了 导出数据: mongoexport -h 127.0.0.1 -u root -p 12345 -d taobao -c prodect --type=cvs -o D:\data\prodect_cvs.dat 不知上述意思的可以参见: Mongo的导出工具mongoexport介绍 然后就报错

12

2017-08-26T15:48:30.940+0800 error connecting to db server: server returned error on SASL authentication step: Authentication failed.

网上搜了一下,说–authenticationDatabase admin 这是是必须的,否则会报上述错误: 解决办法 再添加一串代码: --authenticationDatabase admin 但是添加了之后还是报相同的错,又搜了一下,看了下面一篇博文

mongoDB authentication

连接到admin数据库,在admin数据库上创建一个用户,这个用户保存在admin.system.users中,它的权限比在其它数据库中设置的用户权限更大。(当admin.system.users中一个用户都没有时,即使mongod启动时添加了–auth参数,如果没有在admin数据库中添加用户,此时不进行任何认证还是可以做任何操作,直到在admin.system.users中添加了一个用户。)

原来是我没创建一个用户但大家要注意创建用户的命令版本不同,命令也有可能不同,我就遇到了这个问题,

mark
mark

mongodb3.X用的方法: mongoDB add user in v3.0 问题的解决(Property ‘addUser’ of object admin is not a func)

我的版本是3.X的,所有我应该执行下面

123456789101112

use admindb.createUser( { user: "appAdmin", pwd: "password", roles: [ { role: "readWrite", db: "config" }, "clusterAdmin" ] })

旧点的版本:

12

use admindb.addUser('appAdmin', 'password')

创建完成之后如下图:

mark
mark

然后又遇到一个问题csv mode requires a field list ,原因是第一次没有指明要导出的列,所以只是实现一个空的文件

123456

user@user-xubuntu:/usr/lib/mongodb/bin$ sudo ./mongoexport -d wx_connect -c template --csv -o template_csv.dat connected to: 127.0.0.1 csv mode requires a field list                     ------第一次没有指明要导出的列,所以只是实现一个空的文件 user@user-xubuntu:/usr/lib/mongodb/bin$ sudo ./mongoexport -d wx_connect -c template --csv -f msgId,templateId,status,toUser -o template_csv_new.dat connected to: 127.0.0.1 exported 28 records                           ------导出成功

所以在末尾再加上-f 一列的名字 mongoexport -h 127.0.0.1 -u root -p 12345 -d taobao -c prodect --type=cvs -o D:\data\prodect_cvs.dat --authenticationDatabase admin -f shop

参考博客: mongoDB的基本操作以及数据的导入导出,备份和恢复 如下图

mark
mark

哇。终于完成了,有点小激动啊!!

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-08-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MongoDB
腾讯云数据库 MongoDB(TencentDB for MongoDB)是腾讯云基于全球广受欢迎的 MongoDB 打造的高性能 NoSQL 数据库,100%完全兼容 MongoDB 协议,支持跨文档事务,提供稳定丰富的监控管理,弹性可扩展、自动容灾,适用于文档型数据库场景,您无需自建灾备体系及控制管理系统。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档