美文网首页
mongoDB入门一

mongoDB入门一

作者: JervieQin | 来源:发表于2018-07-14 10:02 被阅读0次

    进行CRUD操作之前有必要了解mongoDB的数据模型

    MongoDB增删改查

    MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。 相较于关系型数据库它最大的优点就是灵活、快速、高效。

    MongoDB基本操作

    创建数据库

    use yourDB //使用一个数据库,如果不存在自动创建。MongoDB很多操作都会在目标不存在的时候创建一个新的可用目标

    删除数据库

    use yourDBdb.dropDatabase()

    创建集合

    db.createCollection("yourCollection")

    创建集合有第二个可选参数 ,给集合增加条件,详情http://www.runoob.com/mongodb/mongodb-create-collection.html

    删除集合

    db.yourCollection.drop()

    MongoDB 对文档进行CURD

    插入

    MongoDB 使用 insert() 或 save() 方法向集合中插入文档,语法如下:

    1.db.COLLECTION_NAME.insert(document)
    2.db.COLLECTION_NAME.insertOne(document)
    3.COLLECTION_NAME.insertMany(【document1,document2,...】,{option}) //多文档插入时,集合必须存在

    实例

    以下文档可以存储在 MongoDB 的 game 数据库 的 Player 集合中:

    db.Player.insert(
    {
    job: '法师', 
    name: '阿三', 
    health: 100, 
    defence: 50, 
    skills: ['skill1', 'skill2', 'skill3']
    }
    )
    

    更新

    Save()方法
    save() 方法通过传入的文档来替换已有文档。所以既能做插入也能做更新。

    update() 方法

    update() 方法用于更新已存在的文档。语法格式如下:

    db.collection.update( <query>, <update>, { upsert: <boolean>, multi: <boolean>, writeConcern: <document> })

    参数说明:

    • query : update的查询条件,类似sql update查询内where后面的。

    • update : update的对象和一些更新的操作符(如​inc...)等,也可以理解为sql update查询内set后面的

    • upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。

    • multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。

    • writeConcern :可选,抛出异常的级别。

    利用上述Player文档做如下更新操作:

    db.Player.update({'job':'法师'},{$set:{'job':'战士'}})

    更新操作符包括:

    字段更新操作: $ + set /unset/inc/min/max 依次表示:替换字段/删除字段/增加字段值/求字段最小值/求字段最大值

    $ + setOnInsert 如果更新函数可选参数upsert为true,仅当完成插入才将值分配给字段

    数组更新操作: $ + addToSet/pop/pull/push/slice 向不存在的数组加值/删除数组头或尾端数据/输出数组所有满足条件的值/将值插入数组

    查询

    MongoDB 查询数据的语法格式如下:

    db.collection.find(query, projection)

    • query :可选,使用查询操作符指定查询条件

    • projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)

    运算符:

    比较查询运算符: $ + eq/gt/gte/in/lt/lte/ne/nin 分别表示 = / > / >= / [,] / < / <= / != / ![,]

    逻辑查询运算符: $ + and/not/nor/or 字面义

    元素查询运算符: $ + exists 字面义

    等式查询运算符: $ +regex 通过正则表达式来查询

    删除操作

    db.collecion.deleteOne(document)
    db.collection.deleteMany(document)

    所有操作运算符文档:https://docs.mongodb.com/manual/reference/operator/
    CRUD文档 :https://docs.mongodb.com/manual/crud/

    相关文章

      网友评论

          本文标题:mongoDB入门一

          本文链接:https://www.haomeiwen.com/subject/wmuepftx.html