通过前一篇文章,已经学习了如何下载安装MongoDB,在本文主要以一些简单的小例子,简述MongoDB的常规操作CRUD【增删改查】,仅供学习分享使用,如有问题,还请指正。
数据库操作
1. 创建及切换数据库
语法:use db_name;
释义:如果数据库存在,则切换到对应数据库;如果数据库不存在,则创建数据库。如下所示:.
2. 显示所有数据库
语法:show dbs;
释义:显示当前连接的所有的数据库,如下所示:
注意:在刚创建完数据库时,通过show dbs进行查看,是不显示的,因为数据库是空的,没有创建集合。
3. 显示当前数据库
语法:db;
释义:显示当前连接的数据库,如下所示:
4. 删除数据库
语法:db.dropDatabase();
释义:删除当前连接的数据库,如果要删除其他数据库,可通过use db_name 进行切换,然后再删除。
示例:删除后,在show dbs时,则不显示,如下所示:
注意:在删除数据库后,通过db命令,依然显示删除后的数据库,这说明了什么?
集合操作
1. 创建集合
语法:db.createCollection(name,option);
释义:创建集合,第一个参数是集合名称,第二个参数是集合选项,属于非必填项。
关于option可选内容,如下所示:
注意:capped和size是一对组合,size大小为KB,max为集合中文档数量。
示例,创建一个名称为person的固定集合,集合大小为102400,最大文档数量为100。如下所示:
创建集合后,再次执行show dbs命令,则会显示创建的数据库,如下所示:
注意:也可以通过insert语句插入文档时,创建对象。在插入文档是,如果集合存在,则插入;如果集合不存在,则创建集合,然后插入文档。
2. 查看已有集合
语法:show collections; 或者 show tables;
释义:显示当前连接数据库中所有集合。
示例:查看hexdb下所有的集合,如下所示:
3. 删除集合
语法:db.集合名.drop();
释义:删除对应的集合及集合中的数据,如果删除成功,返回true。
示例:删除person集合,如下所示:
4. 插入文档
集合中的文档,是以BSON【Binary JSON】形式存在的。
语法:db.collection_name.insert(document);
释义:往指定集合中插入文档。
示例:通过insert语句往集合中插入数据,如果集合不存在,则创建,如下所示:
注意:数据库已经删除,但是在创建集合后,又奇迹般的出现了。说明之前的删除数据库,只是将数据库中的集合给删除了。
5. 一次插入多条文档
执行一次语句,插入多条文档
语法:db.集合名.insert([{文档1},{文档2},{文档3}]);
释义:执行一次语句,插入多条文档。
示例:一次插入3条文档,并进行查询。如下所示:
6. 查询文档
查询集合中的文档,
语法:db.集合名.find(condition);
释义:根据条件查询集合中的文档,如果条件为空,则查询集合中所有文档。
示例:先查询所有文档,在根据名称进行检索,如下所示:
7. 更新文档
根据指定条件,更新对应文档的内容。
更新文档语法如下所示:
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 :可选,抛出异常的级别。
示例:更新lisi的年龄为28,分别用1:表示更新前,2:更新语句,3:更新后。如下所示:
8. 多个条件更新文档
1. 多个条件同时满足时,才能更新文档。
语法:{条件1,条件2,条件3,...}
在多个条件需要同时满足时,用逗号隔开,如下所示:
2. 多个条件有一个满足时,即可修改文档。
语法:$or:[{条件1},{条件2},{条件3}]。如下所示:
9. 删除文档
根据指定条件,删除对应文档。
语法:
db.collection.remove(
<query>,
<justOne>
)
参数说明:
-
query :(可选)删除的文档的条件。
-
justOne : (可选)如果设为 true 或 1,则只删除一个文档,如果不设置该参数,或使用默认值 false,则删除所有匹配条件的文档。
-
writeConcern :(可选)抛出异常的级别。
示例:删除名称为zhangsan的文档,如下所示:
10. 删除集合中所有文档
语法:db.集合名.remove({});
释义:不带条件,则表示删除集合中所有文档。
MongoDB数据类型
MongoDB的数据类型,不像关系型数据库的数据类型,需要预先定义,而是根据存储的值的类型来的。数据类型如下所示:
以上就是MongoDB基础知识介绍,关于NoSQL基础知识以及安装知道,可参考之前的文章。