设为首页 收藏本站
查看: 1349|回复: 0

[经验分享] Linux下MongoDB的安装和操作

[复制链接]

尚未签到

发表于 2018-10-26 11:13:39 | 显示全部楼层 |阅读模式
  Mongo DB ,是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式,备受当前IT从业人员的青睐。Mongo DB很好的实现了面向对象的思想(OO思想),在Mongo DB中 每一条记录都是一个Document对象。Mongo DB最大的优势在于所有的数据持久操作都无需开发人员手动编写SQL语句,直接调用方法就可以轻松的实现CRUD操作。
  一、下载mongodb
  前往mongodb官网下载页面:https://www.mongodb.org/downloads下载相应的版本,比如目前的Linux x64位最新版:mongodb-linux-x86_64-2.6.4.tgz
  不过有点坑爹是,下载链接明明是tgz格式,结果下载后变成了gz格式:
  mongodb1
  先下载看看好了。
  二、解压mongodb
  [root@test6 ~]# gzip -d mongodb-linux-x86_64-2.6.4.gz
  得到的是mongodb-linux-x86_64-2.6.4,居然是个文件,而不是文件夹,和网上说的大相径庭:
  mongodb2
  看来前面下载的确实存在问题!实际上应该是tgz文件才对,按经验分析了一下,下载的实际上还是tgz文件,显示为gz文件只是形式上的假象!所以,gzip只解压了压缩包的外层,实际上还需要解压一层tar存档属性!
  于是,先将解压后的文件重命名加上tar格式:
  [root@test6 ~]# mv mongodb-linux-x86_64-2.6.4 mongodb-linux-x86_64-2.6.4.tar
  然后,使用tar解压即可:
  ?1 [root@test6 ~]# tar xvf mongodb-linux-x86_64-2.6.4.tar
  将解压后的文件夹移动&重命名至/usr/local/mongodb
  [root@test6 ~]# mv mongodb-linux-x86_64-2.6.4 /usr/local/mongodb [root@test6 ~]# cd /usr/local/mongodb/bin/ [root@test6 ~]# ll
  bin下的mongod就是MongoDB的服务端进程,mongo就是其客户端,其它的命令用于MongoDB的其它用途如MongoDB文件导出等。
  三、启动mongodb
  启动前,先指定mongodb的data目录,如果没有就创建一个:
  [root@test6 ~]# cd /usr/local/mongodb [root@test6 mongodb]# mkdir data
  然后,执行如下命令即可启动mongodb:
  [root@test6 mongodb]# /usr/local/mongodb/bin/mongod --dbpath=/usr/local/mongodb/data/ --logpath=/usr/local/mongodb/data/mongodb.log --logappend&
  mongodb5
  启动成功后,可查看是否启动成功了,默认端口号是27017,当然在启动时也可以指定未使用的其它端口。
  mongodb6
  最后,将客户端mogo文件在/bin下软链接,方便随处执行:
  ln -s /usr/local/mongodb/bin/mongo /bin/mongo
  现在使用mongo客户端访问一下该数据库:
  [root@test6 bin]# ./mongo MongoDB shell version: 2.6.4 connecting to: test >
  安装成功!
  四、附:基本操作

  MongoDB数据库基本用法   show dbs:显示数据库列表  show collections:显示当前数据库中的集合(类似关系数据库中的表)  show users:显示用户 use :切换当前数据库,这和MS-SQL里面的意思一样  db.help():显示数据库操作命令,里面有很多的命令  db.foo.help():显示集合操作命令,同样有很多的命令,foo指的是当前数据库下,一个叫foo的集合,并非真正意义上的命令  db.foo.find():对于当前数据库中的foo集合进行数据查找(由于没有条件,会列出所有数据)  db.foo.find( { a : 1 } ):对于当前数据库中的foo集合进行查找,条件是数据中有一个属性叫a,且a的值为1 MongoDB没有创建数据库的命令,但有类似的命令。 如:如果你想创建一个“myTest”的数据库,先运行use myTest命令,之后就做一些操作(如:db.createCollection('user')),这样就可以创建一个名叫“myTest”的数据库。 数据库常用命令   1、Help查看命令提示  help  db.help();  db.yourColl.help();  db.youColl.find().help();  rs.help(); 2、切换/创建数据库  use yourDB; 当创建一个集合(table)的时候会自动创建当前数据库 3、查询所有数据库  show dbs; 4、删除当前使用数据库  db.dropDatabase(); 5、从指定主机上克隆数据库  db.cloneDatabase(“127.0.0.1”); 将指定机器上的数据库的数据克隆到当前数据库 6、从指定的机器上复制指定数据库数据到某个数据库  db.copyDatabase("mydb", "temp", "127.0.0.1");将本机的mydb的数据复制到temp数据库中 7、修复当前数据库  db.repairDatabase(); 8、查看当前使用的数据库  db.getName();  db; db和getName方法是一样的效果,都可以查询当前使用的数据库 9、显示当前db状态  db.stats(); 10、当前db版本  db.version(); 11、查看当前db的链接机器地址  db.getMongo();   Collection聚集集合   1、创建一个聚集集合(table)  db.createCollection(“collName”, {size: 20, capped: 5, max: 100}); 2、得到指定名称的聚集集合(table)  db.getCollection("account"); 3、得到当前db的所有聚集集合  db.getCollectionNames(); 4、显示当前db所有聚集索引的状态  db.printCollectionStats();   用户相关   1、添加一个用户  db.addUser("name");  db.addUser("userName", "pwd123", true); 添加用户、设置密码、是否只读 2、数据库认证、安全模式  db.auth("userName", "123123"); 3、显示当前所有用户  show users; 4、删除用户  db.removeUser("userName");   其他   1、查询之前的错误信息  db.getPrevError(); 2、清除错误记录  db.resetError();    查看聚集集合基本信息   1、查看帮助 db.yourColl.help(); 2、查询当前集合的数据条数 db.yourColl.count(); 3、查看数据空间大小 db.userInfo.dataSize(); 4、得到当前聚集集合所在的db db.userInfo.getDB(); 5、得到当前聚集的状态 db.userInfo.stats(); 6、得到聚集集合总大小 db.userInfo.totalSize(); 7、聚集集合储存空间大小 db.userInfo.storageSize(); 8、Shard版本信息 db.userInfo.getShardVersion() 9、聚集集合重命名 db.userInfo.renameCollection("users"); 将userInfo重命名为users 10、删除当前聚集集合 db.userInfo.drop();   聚集集合查询   1、查询所有记录 db.userInfo.find(); 相当于:select* from userInfo; 默认每页显示20条记录,当显示不下的情况下,可以用it迭代命令查询下一页数据。注意:键入it命令不能带“;” 但是你可以设置每页显示数据的大小,用DBQuery.shellBatchSize= 50;这样每页就显示50条记录了。    2、查询去掉后的当前聚集集合中的某列的重复数据 db.userInfo.distinct("name"); 会过滤掉name中的相同数据 相当于:select distict name from userInfo;    3、查询age = 22的记录 db.userInfo.find({"age": 22}); 相当于: select * from userInfo where age = 22;    4、查询age > 22的记录 db.userInfo.find({age: {$gt: 22}}); 相当于:select * from userInfo where age >22;    5、查询age < 22的记录 db.userInfo.find({age: {$lt: 22}}); 相当于:select * from userInfo where age = 25的记录 db.userInfo.find({age: {$gte: 25}}); 相当于:select * from userInfo where age >= 25;    7、查询age = 23 并且 age  25 db.userInfo.find({age: {$gt: 25}}, {name: 1, age: 1}); 相当于:select name, age from userInfo where age >25;    13、按照年龄排序 升序:db.userInfo.find().sort({age: 1}); 降序:db.userInfo.find().sort({age: -1});    14、查询name = zhangsan, age = 22的数据 db.userInfo.find({name: 'zhangsan', age: 22}); 相当于:select * from userInfo where name = ‘zhangsan' and age = ‘22';    15、查询前5条数据 db.userInfo.find().limit(5); 相当于:selecttop 5 * from userInfo;    16、查询10条以后的数据 db.userInfo.find().skip(10); 相当于:select * from userInfo where>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-626706-1-1.html 上篇帖子: MongoDB数据库学习笔记 下篇帖子: mongodb关闭方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表