zoukankan      html  css  js  c++  java
  • ubuntu安装mongodb

    sudo apt-get install mongodb【安装数据库】

    启动和关闭mongodb命令如下:

    service mongodb start   【开启服务】
    service mongodb stop   【关闭服务】

    卸载MongoDB

    sudo apt-get --purge remove mongodb mongodb-clients mongodb-server

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

    pgrep mongo -l


    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”的数据库。

    1、切换到School数据库

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

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

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

    db.student.insert({_id:1, sname: 'zhangsan', sage: 20}) #_id可选
    db.student.save({_id:1, sname: 'zhangsan', sage: 22}) #_id可选
    这两种方式,其插入的数据中_id字段均可不写,会自动生成一个唯一的_id来标识本条数据。而insert和save不同之处在于:在手动插入_id字段时,如果_id已经存在,insert不做操作,save做更新操作;如果不加_id字段,两者作用相同都是插入数据

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

    db.student.find() #查询所有记录。相当于:select * from student
    db.student.find({sname: 'lisi'}) #查询sname='lisi'的记录。相当于: select * from student where sname='lisi'
    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字段了
    db.student.find({sname: 'zhangsan', sage: 22}) #and 与条件查询。相当于:select * from student where sname = 'zhangsan' and sage = 22
    db.student.find({$or: [{sage: 22}, {sage: 25}]}) #or 条件查询。相当于:select * from student where sage = 22 or sage = 25

    
    

    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可选参数

    举例如下:

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

    5、删除数据

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

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

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

     
  • 相关阅读:
    聪明的质检员 (二分)
    分巧克力(二分)
    产生冠军 HDU
    Legal or Not HDU
    确定比赛名次 HDU
    最短路径问题 HDU
    dijkstra算法为什么不能有负边?
    最短路 HDU
    dijkstra算法 模板
    Floyd算法模板--详解
  • 原文地址:https://www.cnblogs.com/duanlinxiao/p/10444594.html
Copyright © 2011-2022 走看看