转 https://blog.csdn.net/flyfish111222/article/details/51886787

本博文介绍了MongoDB,并详细指引读者在Ubuntu下MongoDB的安装和使用。本教程在Ubuntu14.04下测试通过。

一、MongoDB介绍

MongoDB
是一个是一个基于分布式文件存储的数据库,介于关系数据库和非关系数据库之间,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

二、安装MongoDB

MongoDB安装很简单,无需下载源文件,可以直接用apt-get命令进行安装。
打开终端,输入以下命令:

  1. sudo apt-get install mongodb
  • 1

截图如下:

安装完成后,在终端输入以下命令查看MongoDB版本:

  1. mongo -version
  • 1

输出版本信息,表明安装成功,截图如下:

启动和关闭mongodb命令如下:

  1. service mongodb start
  2. service mongodb stop
  • 1
  • 2

截图如下:

默认设置MongoDB是随Ubuntu启动自动启动的。
输入以下命令查看是否启动成功:

  1. pgrep mongo -l #注意:-l是英文字母l,不是阿拉伯数字1
  • 1

截图如下:

卸载MongoDB

  1. sudo apt-get --purge remove mongodb mongodb-clients mongodb-server
  • 1

三、使用MongoDB

shell命令模式

输入mongo进入shell命令模式,默认连接的数据库是test数据库,在此之前一定要确保你已经启动了MongoDB,否则会出现错误,启动之后运行成功,如下截图:

常用操作命令:

数据库相关
show dbs:显示数据库列表
show collections:显示当前数据库中的集合(类似关系数据库中的表table)
show users:显示所有用户
use yourDB:切换当前数据库至yourDB
db.help() :显示数据库操作命令
db.yourCollection.help() :显示集合操作命令,yourCollection是集合名
MongoDB没有创建数据库的命令,如果你想创建一个“School”的数据库,先运行use School命令,之后做一些操作(如:创建聚集集合db.createCollection('teacher')),这样就可以创建一个名叫“School”的数据库。截图如下:

下面以一个School数据库为例,在School数据库中创建两个集合teacher和student,并对student集合中的数据进行增删改查基本操作(集合Collection相当于关系型数据库中的表table)。
1、切换到School数据库

  1. use School #切换到School数据库。MongoDB 无需预创建School数据库,在使用时会自动创建
  • 1

2、创建Collection

  1. db.createCollection('teacher') #创建一个聚集集合。MongoDB 其实在插入数据的时候,也会自动创建对应的集合,无需预定义集合
  • 1

截图如下:

3、插入数据
与数据库创建类似,插入数据时也会自动创建集合。
插入数据有两种方式:insert和save。

  1. db.student.insert({_id:1, sname: 'zhangsan', sage: 20}) #_id可选
  2. db.student.save({_id:1, sname: 'zhangsan', sage: 22}) #_id可选
  • 1
  • 2

这两种方式,其插入的数据中_id字段均可不写,会自动生成一个唯一的_id来标识本条数据。而insert和save不同之处在于:在手动插入_id字段时,如果_id已经存在,insert不做操作,save做更新操作;如果不加_id字段,两者作用相同都是插入数据。截图如下:

添加的数据其结构是松散的,只要是bson格式均可,列属性均不固定,根据添加的数据为准。先定义数据再插入,就可以一次性插入多条数据,截图如下:

运行完以上例子,student 已自动创建,这也说明 MongoDB 不需要预先定义 collection ,在第一次插入数据后,collection 会自动的创建。截图如下:

3、查找数据
db.youCollection.find(criteria, filterDisplay)
criteria :查询条件,可选
filterDisplay:筛选显示部分数据,如显示指定列数据,可选(当选择时,第一个参数不可省略,若查询条件为空,可用{}做占位符,如下例第三句)

  1. db.student.find() #查询所有记录。相当于:select * from student
  2. db.student.find({sname: 'lisi'}) #查询sname='lisi'的记录。相当于: select * from student where sname='lisi'
  3. db.student.find({},{sname:1, sage:1}) #查询指定列sname、sage数据。相当于:select sname,sage from student。sname:1表示返回sname列,默认_id字段也是返回的,可以添加_id:0(意为不返回_id)写成{sname: 1, sage: 1,_id:0},就不会返回默认的_id字段了
  4. db.student.find({sname: 'zhangsan', sage: 22}) #and 与条件查询。相当于:select * from student where sname = 'zhangsan' and sage = 22
  5. db.student.find({$or: [{sage: 22}, {sage: 25}]}) #or 条件查询。相当于:select * from student where sage = 22 or sage = 25
  • 1
  • 2
  • 3
  • 4
  • 5

查询操作类似,这里只给出db.student.find({sname: 'lisi'})查询的截图,如下:

4、修改数据
db.youCollection.update(criteria, objNew, upsert, multi )
criteria: update的查询条件,类似sql update查询内where后面的
objNew : update的对象和一些更新的操作符(如$set)等,也可以理解为sql update查询内set后面的。
upsert : 如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi: mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。默认false,只修改匹配到的第一条数据。
其中criteria和objNew是必选参数,upsert和multi可选参数
举例如下:

  1. db.student.update({sname: 'lisi'}, {$set: {sage: 30}}, false, true) #相当于:update student set sage =30 where sname = 'lisi';
  • 1

操作截图如下:

5、删除数据

  1. db.student.remove({sname: 'chenliu'}) #相当于:delete from student where sname='chenliu'
  • 1

操作截图如下:

6、退出shell命令模式
输入exit或者Ctrl+C退出shell命令模式

注意:MongoDB相较安全性更偏向易用性,默认是没有开启用户权限的,如果想开启用户权限,可以参考Ubuntu下开启MongoDB用户权限

Java API编程实例

第一步:下载Java MongoDB Driver驱动jar包,Java MongoDB Driver下载地址,默认的下载目录为~/下载或者~/Downloads
第二步:打开Eclipse,新建Java Project,新建Class,引入刚刚下载的jar包
第三步:编码实现
下面是源代码:

  1. import java.util.ArrayList;
  2. import java.util.List;
  3. import org.bson.Document;
  4. import com.mongodb.MongoClient;
  5. import com.mongodb.client.MongoCollection;
  6. import com.mongodb.client.MongoCursor;
  7. import com.mongodb.client.MongoDatabase;
  8. import com.mongodb.client.model.Filters;
  9. public class TestMongoDB {
  10. /**
  11. * @param args
  12. */
  13. public static void main(String[] args) {
  14. insert();//插入数据。执行插入时,可将其他三句函数调用语句注释掉,下同
  15. // find(); //查找数据
  16. // update();//更新数据
  17. // delete();//删除数据
  18. }
  19. /**
  20. * 返回指定数据库中的指定集合
  21. * @param dbname 数据库名
  22. * @param collectionname 集合名
  23. * @return
  24. */
  25. //MongoDB无需预定义数据库和集合,在使用的时候会自动创建
  26. public static MongoCollection<Document> getCollection(String dbname,String collectionname){
  27. //实例化一个mongo客户端,服务器地址:localhost(本地),端口号:27017
  28. MongoClient mongoClient=new MongoClient("localhost",27017);
  29. //实例化一个mongo数据库
  30. MongoDatabase mongoDatabase = mongoClient.getDatabase(dbname);
  31. //获取数据库中某个集合
  32. MongoCollection<Document> collection = mongoDatabase.getCollection(collectionname);
  33. return collection;
  34. }
  35. /**
  36. * 插入数据
  37. */
  38. public static void insert(){
  39. try{
  40. //连接MongoDB,指定连接数据库名,指定连接表名。
  41. MongoCollection<Document> collection= getCollection("test","student");
  42. //实例化一个文档,文档内容为{sname:'Mary',sage:25},如果还有其他字段,可以继续追加append
  43. Document doc1=new Document("sname","Mary").append("sage", 25);
  44. //实例化一个文档,文档内容为{sname:'Bob',sage:20}
  45. Document doc2=new Document("sname","Bob").append("sage", 20);
  46. List<Document> documents = new ArrayList<Document>();
  47. //将doc1、doc2加入到documents列表中
  48. documents.add(doc1);
  49. documents.add(doc2);
  50. //将documents插入集合
  51. collection.insertMany(documents);
  52. System.out.println("插入成功");
  53. }catch(Exception e){
  54. System.err.println( e.getClass().getName() + ": " + e.getMessage() );
  55. }
  56. }
  57. /**
  58. * 查询数据
  59. */
  60. public static void find(){
  61. try{
  62. MongoCollection<Document> collection = getCollection("test","student");
  63. //通过游标遍历检索出的文档集合
  64. // MongoCursor<Document> cursor= collection.find(new Document("sname","Mary")). projection(new Document("sname",1).append("sage",1).append("_id", 0)).iterator(); //find查询条件:sname='Mary'。projection筛选:显示sname和sage,不显示_id(_id默认会显示)
  65. //查询所有数据
  66. MongoCursor<Document> cursor= collection.find().iterator();
  67. while(cursor.hasNext()){
  68. System.out.println(cursor.next().toJson());
  69. }
  70. }catch(Exception e){
  71. System.err.println( e.getClass().getName() + ": " + e.getMessage() );
  72. }
  73. }
  74. /**
  75. * 更新数据
  76. */
  77. public static void update(){
  78. try{
  79. MongoCollection<Document> collection = getCollection("test","student");
  80. //更新文档 将文档中sname='Mary'的文档修改为sage=22
  81. collection.updateMany(Filters.eq("sname", "Mary"), new Document("$set",new Document("sage",22)));
  82. System.out.println("更新成功!");
  83. }catch(Exception e){
  84. System.err.println( e.getClass().getName() + ": " + e.getMessage() );
  85. }
  86. }
  87. /**
  88. * 删除数据
  89. */
  90. public static void delete(){
  91. try{
  92. MongoCollection<Document> collection = getCollection("test","student");
  93. //删除符合条件的第一个文档
  94. collection.deleteOne(Filters.eq("sname", "Bob"));
  95. //删除所有符合条件的文档
  96. //collection.deleteMany (Filters.eq("sname", "Bob"));
  97. System.out.println("删除成功!");
  98. }catch(Exception e){
  99. System.err.println( e.getClass().getName() + ": " + e.getMessage() );
  100. }
  101. }
  102. }

每次执行完程序,都可以返回shell模式查看结果。如:在eclipse执行完更新操作后,在shell模式输入db.student.find(),可以查看student集合的所有数据,截图如下:

ubantu MongoDB安装的更多相关文章

  1. mongodb安装&简单使用

    转自Mac下使用brew安装mongodb,按着步骤已成功安装. brew常用命令 1.更新brew本身 brew update 2.使用brew安装软件 1 brew install soft_na ...

  2. win7 64位下 mongodb安装及命令运行

    有网友老催我把框架加上mongodb的支持,于是偶尔抽空看了看相关的文章. 今天有缘,就把mongodb安装了一下,中间遇到了小小的问题,So,把整个过程记录一下: 1:先上官网:http://www ...

  3. MongoDB配置服务--MongoDB安装成为windows服务

    MongoDB安装成为windows服务 1.打开命令提示符(最好以管理员的身份打开),然后输入: mongod --logpath "D:\MongoDB\data\log\logs.tx ...

  4. [MongoDB]安装MongoDB

    汇总: 1. [MongoDB]安装MongoDB2. [MongoDB]Mongo基本使用:3. [MongoDB]MongoDB的优缺点及与关系型数据库的比较4. [MongoDB]MongoDB ...

  5. MongoDB学习:(一)MongoDB安装

    MongoDB学习:(一)MongoDB安装 MongoDB介绍:     直接百科了: MongoDB安装: 1:下载安装: MongoDB安装:https://www.mongodb.com/do ...

  6. MongoDB 安装(Window/Linux)

    MongoDB安装在Windows上 在 Windows上,首先要安装 MongoDB下载最新发布的MongoDB: http://www.mongodb.org/downloads 确保得到正确的版 ...

  7. MongoDB安装与启动

    我本人电脑是win8系统64位,下载64位的zip包,下载完成后解压缩到D:\MongoDB目录 创建数据库目录D:\MongoDB\data,接下来打开命令行窗口,切换到D:\MongoDB\bin ...

  8. MongoDB安装部署(一)

    前言 MongoDB是一个由C++语言编写的基于分布式文件存储的数据库,是当前NoSQL数据库中比较热门的一种,旨在为Web应用提供可扩展的高性能数据存储解决方案. MongoDB 简介 MongoD ...

  9. windows下mongodb安装与使用整理

    一.首先安装mongodb 1.下载地址:http://www.mongodb.org/downloads 2.解压缩到自己想要安装的目录,比如d:\mongodb 3.创建文件夹d:\mongodb ...

随机推荐

  1. anaconda是个啥?

    Anaconda具有跨平台(win/mac/linux).包管理(类似于pip).环境管理(类似于virtualenv)的特点,因此很适合快速在新的机器上部署Python环境 Anaconda利用工具 ...

  2. 看我如何基于Python&Facepp打造智能监控系统

    由于种种原因,最近想亲自做一个基于python&facepp打造的智能监控系统. 0×00:萌芽 1:暑假在家很无聊 想出去玩,找不到人.玩个lol(已卸载),老是坑人.实在是无聊至极,不过, ...

  3. 正则表达式的捕获组(capture group)在Java中的使用

    原文:http://blog.csdn.net/just4you/article/details/70767928 ------------------------------------------ ...

  4. Androidbuttonshape形状资源码实现

    1.项目Src下创建drawable 看文档Develop/API Guides/App Resources/Drawable/Shape Drawable 单词:corners : 角  ;  gr ...

  5. C#如何开发多语言支持的Winform程序

    C# Winform项目多语言实现(支持简/繁/英三种语言)有很多种方案实现多语言,我在这里介绍一种最简单最容易理解的,作为教学材题应该从通俗易懂入手.在写这篇文章之前,本来想用枚举窗体对象成员的方式 ...

  6. UVa 10950 - Bad Code

    题目:有一种编码方式.串仅仅有小写字母构成,每一个小写字母相应一个数字,如今给你妆化后的数字串, 问有多少个原串与之相应,注意数字串里可能有一个前导0. 分析:搜索.按字母顺序存储映射表,按字母顺序匹 ...

  7. Unity3D 游戏引擎之C#使用Socket与HTTP连接server数据传输包

    近期比較忙.有段时间没写博客拉.近期项目中须要使用HTTP与Socket.雨松MOMO把自己这段时间学习的资料整理一下. 有关Socket与HTTP的基础知识MOMO就不赘述拉,不懂得朋友自己谷歌吧. ...

  8. 何时、怎样开启 MySql 日志?

    假如你是一名 web 开发者.假设你想调试你的应用或提升其性能的话,那你须要去參考各种日志文件.日志是開始故障排除最好的选择.就著名的 MySql 数据库server而言,你须要參考下面日志文件: 错 ...

  9. 几种查看CentOS系统版本号和位数的方法

    查看系统版本号: cat /etc/redhat-release cat /proc/version uname -a cat /etc/issue 查看64位还是32位: getconf LONG_ ...

  10. kentico7中设置site的default page

    在SiteManager中,Settings中,选择好站点,然后Content,Default alias path