首页 > 技术文章 > mongodb4简明笔记

absudra 2018-09-06 19:15 原文

就一数据库,掌握基本用法,其他的现学现卖就行了.

所以要把握基本套路.

创建数据库=>使用数据库=>创建集合=>使用集合=>创建文档=>使用文档

1.数据库

mongodb和mysql目前我发现了一个比较明显的区别是:

  mysql要想使用一个数据库,必须先创建一个数据库,而mongodb是直到你真正想某个数据库写入才会生成这个数据库.

数据库基本操作无非那么几个:

创建数据库:

如上所述,不存在的,简单的:use dbname

查看数据库都那些:show dbs

删除数据库:

db.dropDatabase()

总结,操作数据库:[创建数据库]=>选择数据库(use)=>删除数据库(db.dropDatabase())

实验证明,如果没有use直接删库,不会删除任何数据库.

2.数据集合

创建:

db.createCollection(collectionName,createOption)

createOption是一个词典,里面可以有4个键值对:capped(固定大小的集合),autoIndexId(真假),size(集合最大值,字节为单位),max(最大文档值)

例如,创建一个autoIndexId,无固定大小,无各种最大值的集合:

db.createCollection("collection1",{autoIndexId:true})

查看当前数据库集合状态:

show collections

删除数据库集合:

db.collectionName.drop()

3.数据行(文档)

 创建|插入:

db.collectionName.insert(document)

如果插入多个文档呢???

db.collectionName.insertMany([document1,document2,...,documentn])

这里面所谓的document,实际是Binary JSON,即BSON,你可以单纯的看成是JSON,或者是Python的字典.

例如,文档格式有个字段,name,age,gender,profession,addr,tel.插入一个这样的信息,则可以写:

db.stu.insert({"name":"ZhangSan","age":22,"gender":"shemale","profession":"chairmanOfSchool","addr":"HeiLongJiang","tel":17777777777"})

MongoDB到目前为止,除了插入文档是必要之外,创建各种库,集合都是可以省略的...

由于MongoDB相对宽松的规则,所以,还可以使用save去插入|更新一些信息,核心就是保存之前不存在的当然就是插入了,保存之前有的就是更新了.用法:

db.collectionName.save(document)

查看集合中的所有文档:

db.stu.find()

删除:

db.collectionName.remove(<query>,{justOne: <boolean>,writeConcern: <document>})

参数全部可选.

删除多个:

db.collectionName.deleteMany({ "name":"ZhangSan" })

更新:

db.collectionName.update(<query>,<update>,{upsert,multi,writeConcern})

其中,后三个都为可选.upsert==update insert.writeConcern(报错级别)

例如: 

db.stu.update({"tel":17777777777"},{$set:{"tel":"1"}})

如果更改某一列(字段),

db.stu.update({"tel":17777777777"},{$set:{"tel":"1"}},{multi:true})

只更新第一条记录:

db.collectionName.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } );

全部更新:

db.collectionName.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true );

只添加第一条:

db.collectionName.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false );

全部添加加进去:

db.collectionName.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true );

全部更新:

db.collectionName.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );

只更新第一条记录:

db.collectionName.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );

查询:

db.collectionName.find(<query>,projection)

其中,projection是可以包含或排除的一些返回结果,所以,例如:

db.collectionName.find({"addr":HeliLongJiang"},{addr:true})

OR:

db.collectionName.find({$or:[{key1:value1},{key2:value2}]})

返回指定字段:

db.CollectionName.find({},{addr:true})

4.数据字段(列)

5.数据索引(下标)

6.数据主键(标识作用的字段)

 

推荐阅读