MongoDB 菜鸟入门“秘籍”
1、mongodb介绍
1.1 什么是mongodb ?
- mongodb 是由c++语言编写的,是一个基于分布式文件存储的开源数据库系统。
- 在高负载的情况下,添加更多的节点,可以保证服务器性能。
- mongodb 旨在为web应用提供可扩展的高性能数据存储解决方案。
- mongodb 将数据存储为一个文档,数据结构由键值(key=>value)对组成。mongodb 文档类似于 json 对象。字段值可以包含其他文档,数组及文档数组。
1.2 主要特点
- mongodb 是一个面向文档存储的数据库,操作起来比较简单和容易。
- 你可以在mongodb记录中设置任何属性的索引 (如:firstname="sameer",address="8 gandhi road")来实现更快的排序。
- 你可以通过本地或者网络创建数据镜像,这使得mongodb有更强的扩展性。
- 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上这就是所谓的分片。
- mongo支持丰富的查询表达式。查询指令使用json形式的标记,可轻易查询文档中内嵌的对象及数组。
- mongodb 使用update()命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
- mongodb中的map/reduce主要是用来对数据进行批量处理和聚合操作。
- map和reduce。map函数调用emit(key,value)遍历集合中所有的记录,将key与value传给reduce函数进行处理。
- map函数和reduce函数是使用javascript编写的,并可以通过db.runcommand或mapreduce命令来执行mapreduce操作。
- gridfs是mongodb中的一个内置功能,可以用于存放大量小文件。
- mongodb允许在服务端执行脚本,可以用javascript编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
- mongodb支持各种编程语言:ruby,python,java,c++,php,c#等多种语言。
- mongodb安装简单。
1.3 mongodb 概念解析
不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。
(1)下表将帮助您更容易理解mongo中的一些概念:
sql术语/概念 | mongodb术语/概念 | 解释/说明 |
---|---|---|
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
table joins | 表连接,mongodb不支持 | |
primary key | primary key | 主键,mongodb自动将_id字段设置为主键 |
通过下图实例,我们也可以更直观的了解mongo中的一些概念:
(2)下表列出了 rdbms 与 mongodb 对应的术语:
rdbms | mongodb |
---|---|
数据库 | 数据库 |
表格 | 集合 |
行 | 文档 |
列 | 字段 |
表联合 | 嵌入文档 |
主键 | 主键 (mongodb 提供了 key 为 _id ) |
数据库服务和客户端 | |
mysqld/oracle | mongod |
mysql/sqlplus | mongo |
1.3.1 文档
(1)介绍
文档是一组键值(key-value)对(即bson)。mongodb 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大的区别,也是 mongodb 非常突出的特点。
一个简单的文档例子如下:
{"site":"www.along.com", "name":"阿龙"}
(2)需要注意的是:
- 文档中的键/值对是有序的。
- 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
- mongodb区分类型和大小写。
- mongodb的文档不能有重复的键。
- 文档的键是字符串。除了少数例外情况,键可以使用任意utf-8字符。
(3)文档键命名规范:
- 键不能含有\0 (空字符)。这个字符用来表示键的结尾。
- .和$有特别的意义,只有在特定环境下才能使用。
- 以下划线"_"开头的键是保留的(不是严格要求的)。
1.3.2 集合
(1)介绍
集合就是 mongodb 文档组,类似于 rdbms (关系数据库管理系统:relational database management system)中的表格。
集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都会有一定的关联性。
比如,我们可以将以下不同数据结构的文档插入到集合中:
{"site":"www.baidu.com"} {"site":"www.google.com","name":"google"} {"site":"www.along.com","name":"阿龙","num":5}
当第一个文档插入时,集合就会被创建。
(2)合法的集合名
- 集合名不能是空字符串""。
- 集合名不能含有\0字符(空字符),这个字符表示集合名的结尾。
- 集合名不能以"system."开头,这是为系统集合保留的前缀。
- 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字里出现$。
如下实例:
db.col.findone()
(3)capped collections
capped collections 就是固定大小的collection。
它有很高的性能以及队列过期的特性(过期按照插入的顺序). 有点和 "rrd" 概念类似。
capped collections 是高性能自动的维护对象的插入顺序。它非常适合类似记录日志的功能和标准的 collection 不同,你必须要显式的创建一个capped collection,指定一个 collection 的大小,单位是字节。 collection 的数据存储空间值提前分配的。
capped collections 可以按照文档的插入顺序保存到集合中,而且这些文档在磁盘上存放位置也是按照插入顺序来保存的,所以当我们更新capped collections 中文档的时候,更新后的文档不可以超过之前文档的大小,这样话就可以确保所有文档在磁盘上的位置一直保持不变。
由于 capped collection 是按照文档的插入顺序而不是使用索引确定插入位置,这样的话可以提高增添数据的效率。mongodb 的操作日志文件 oplog.rs 就是利用 capped collection 来实现的。
要注意的是指定的存储大小包含了数据库的头信息。
db.createcollection("mycoll", {capped:true, size:100000})
- 在 capped collection 中,你能添加新的对象。
- 能进行更新,然而,对象不会增加存储空间。如果增加,更新就会失败 。
- 使用 capped collection 不能删除一个文档,可以使用 drop() 方法删除 collection 所有的行。
- 删除之后,你必须显式的重新创建这个 collection。
- 在32bit机器中,capped collection 最大存储为 1e9( 1x109)个字节。
1.3.3 数据库
(1)介绍
在mongodb中,多个文档组成集合,多个集合可以组成数据库。
一个mongodb中可以建立多个数据库。
mongodb的默认数据库为"db",该数据库存储在data目录中。
mongodb的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据库也放置在不同的文件中。
(2)命令操作
① "show dbs" 命令可以显示所有数据的列表。
> show dbs admin 0.000gb config 0.000gb local 0.000gb
② 执行 "db" 命令可以显示当前数据库对象或集合。
> db admin
③ 运行"use"命令,可以连接到一个指定的数据库,如果数据库不存在会创建数据库。
> use local switched to db local > db local
(3)数据库也通过名字来标识。数据库名可以是满足以下条件的任意utf-8字符串。
- 不能是空字符串("")。
- 不得含有' '(空格)、.、$、/、\和\0 (空字符)。
- 应全部小写。
- 最多64字节。
(4)有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库。
- admin: 从权限的角度来看,这是"root"数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器。
- local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合
- config: 当mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。
1.3.4 元数据
(1)数据库的信息是存储在集合中。它们使用了系统的命名空间:
dbname.system.*
(2)在mongodb数据库中名字空间 <dbname>.system.* 是包含多种系统信息的特殊集合(collection),如下:
集合命名空间 | 描述 |
---|---|
dbname.system.namespaces | 列出所有名字空间。 |
dbname.system.indexes | 列出所有索引。 |
dbname.system.profile | 包含数据库概要(profile)信息。 |
dbname.system.users | 列出所有可访问数据库的用户。 |
dbname.local.sources | 包含复制对端(slave)的服务器信息和状态。 |
(3)对于修改系统集合中的对象有如下限制。
在{{system.indexes}}插入数据,可以创建索引。但除此之外该表信息是不可变的(特殊的drop index命令将自动更新相关信息)。
{{system.users}}是可修改的。 {{system.profile}}是可删除的。
1.4 mongodb 数据类型
下表为mongodb中常用的几种数据类型。
数据类型 | 描述 |
---|---|
string | 字符串。存储数据常用的数据类型。在 mongodb 中,utf-8 编码的字符串才是合法的。 |
integer | 整型数值。用于存储数值。根据你所采用的服务器,可分为 32 位或 64 位。 |
boolean | 布尔值。用于存储布尔值(真/假)。 |
double | 双精度浮点值。用于存储浮点值。 |
min/max keys | 将一个值与 bson(二进制的 json)元素的最低值和最高值相对比。 |
array | 用于将数组或列表或多个值存储为一个键。 |
timestamp | 时间戳。记录文档修改或添加的具体时间。 |
object | 用于内嵌文档。 |
null | 用于创建空值。 |
symbol | 符号。该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用特殊符号类型的语言。 |
date | 日期时间。用 unix 时间格式来存储当前日期或时间。你可以指定自己的日期时间:创建 date 对象,传入年月日信息。 |
object id | 对象 id。用于创建文档的 id。 |
binary data | 二进制数据。用于存储二进制数据。 |
code | 代码类型。用于在文档中存储 javascript 代码。 |
regular expression | 正则表达式类型。用于存储正则表达式。 |
下面说明下几种重要的数据类型。
1.4.1 objectid
(1)介绍
objectid 类似唯一主键,可以很快的去生成和排序,包含 12 bytes,含义是:
- 前 4 个字节表示创建 unix 时间戳,格林尼治时间 utc 时间,比北京时间晚了 8 个小时
- 接下来的 3 个字节是机器标识码
- 紧接的两个字节由进程 id 组成 pid
- 最后三个字节是随机数
(2)注意
mongodb 中存储的文档必须有一个 _id 键。这个键的值可以是任何类型的,默认是个 objectid 对象
由于 objectid 中保存了创建的时间戳,所以你不需要为你的文档保存时间戳字段,你可以通过 gettimestamp 函数来获取文档的创建时间:
> var newobject = objectid() > newobject.gettimestamp() isodate("2018-12-28t03:22:25z")
(3)objectid 转为字符串
> newobject.str 5c25972c9c9c7e85af88d54f
1.4.2 字符串
bson 字符串都是 utf-8 编码。
1.4.3 时间戳
bson 有一个特殊的时间戳类型用于 mongodb 内部使用,与普通的 日期 类型不相关。 时间戳值是一个 64 位的值。其中:
- 前32位是一个 time_t 值(与unix新纪元相差的秒数)
- 后32位是在某秒中操作的一个递增的序数
在单个 mongod 实例中,时间戳值通常是唯一的。
在复制集中, oplog 有一个 ts 字段。这个字段中的值使用bson时间戳表示了操作时间。
bson 时间戳类型主要用于 mongodb 内部使用。在大多数情况下的应用开发中,你可以使用 bson 日期类型。
1.4.4 日期
表示当前距离 unix新纪元(1970年1月1日)的毫秒数。日期类型是有符号的, 负数表示 1970 年之前的日期。
> var mydate1 = new date() //格林尼治时间 > mydate1 isodate("2018-12-28t03:12:02.646z") > typeof mydate1 object > var mydate2 = isodate() //格林尼治时间 > mydate2 isodate("2018-12-28t03:12:15.669z") > typeof mydate2 object
这样创建的时间是日期类型,可以使用 js 中的 date 类型的方法。
返回一个时间类型的字符串:
> var mydate1str = mydate1.tostring() > mydate1str fri dec 28 2018 11:12:02 gmt+0800 (cst) > typeof mydate1str string
或者
> date() fri dec 28 2018 11:13:34 gmt+0800 (cst)
2、下载安装、启动mongodb
2.1 下载mongodb
mongodb 提供了 linux 各发行版本 64 位的安装包,你可以在官网下载安装包。
下载地址:,选择自己需要的版本
下载完安装包,并解压 tgz(以下演示的是 64 位 linux上的安装)
(1)解压
[root@along ~]# cd /usr/local/ [root@along local]# tar -xzvf mongodb-linux-x86_64-4.0.5.tgz
(2)创建软连接,方便以后更换版本
[root@along local]# ln -s mongodb-linux-x86_64-4.0.5 mongodb
(3)配置环境变量
[root@along local]# vim /etc/profile.d/mongodb.sh
[root@along local]# cat /etc/profile.d/mongodb.sh
export mongodb_home=/usr/local/mongodb export path=$path:$mongodb_home/bin
[root@along local]# source /etc/profile.d/mongodb.sh
2.2 编写配置文件
(1)准备mongodb所需的目录
[root@along ~]# cd /usr/local/mongodb
[root@along mongodb]# mkdir etc data log
[root@along mongodb]# touch log/mongod.log
(2)编写配置文件,借鉴
[root@along mongodb]# vim etc/mongodb.conf
# mongod.conf # for documentation of all options, see: # http://docs.mongodb.org/manual/reference/configuration-options/ # where to write logging data. systemlog: destination: file logappend: true path: /usr/local/mongodb/mongod.log # where and how to store data. storage: dbpath: /usr/local/mongodb/data journal: enabled: true # engine: # wiredtiger: # how the process runs processmanagement: fork: true # fork and run in background pidfilepath: /usr/local/mongodb/mongod.pid # location of pidfile #timezoneinfo: /usr/share/zoneinfo # network interfaces net: port: 27017 bindip: 0.0.0.0 # enter 0.0.0.0,:: to bind to all ipv4 and ipv6 addresses or, alternatively, use the net.bindipall setting. security: authorization: enabled
2.3 启动mongodb
(1)使用命令启动mongodb
[root@along mongodb]# mongod -f etc/mongodb.conf
[root@along mongodb]# mongod --shutdown -f /etc/mongodb.conf ---关闭服务命令
[root@along mongodb]# ss -nutlp |grep 27017
tcp listen 0 128 *:27017 *:* users:(("mongod",pid=12961,fd=11))
(2)将mongodb设为开机自启
[root@along ~]# vim /etc/init.d/mongodb
#!/bin/bash export mongo_home=/usr/local/mongodb #chkconfig:2345 20 90 #description:mongod #processname:mongod case $1 in start) $mongo_home/bin/mongod --config $mongo_home/etc/mongodb.conf ;; stop) $mongo_home/bin/mongod --shutdown --config $mongo_home/etc/mongodb.conf ;; status) ps -ef | grep mongod ;; restart) $mongo_home/bin/mongod --shutdown --config $mongo_home/etc/mongodb.conf $mongo_home/bin/mongod --config $mongo_home/etc/mongodb.conf ;; *) echo "require start|stop|status|restart" ;; esac
[root@along ~]# chmod +x /etc/init.d/mongodb
[root@along ~]# chkconfig --add /etc/init.d/mongodb
可以使用systemctl 启动关闭mongodb服务器
[root@along ~]# systemctl start mongodb
[root@along ~]# systemctl stop mongodb
2.4 登入mongodb
[root@along ~]# mongo
mongodb shell version v4.0.5 connecting to: mongodb://127.0.0.1:27017/?gssapiservicename=mongodb implicit session: session { "id" : uuid("b12b375a-ed71-4a65-8a05-e7792ca8cd82") } mongodb server version: 4.0.5 >
3、mongodb安全管理
上面我们所做的所有的操作都没有涉及到用户,我们在用oracle、mysql或者mssql时都有用户名密码需要登录才可以操作,mongodb中当然也有,但是需要我们手动添加。在添加之前,我们先来说说mongodb中用户管理的几个特点:
- mongodb中的账号是在某一个库里边进行设置的,我们在哪一个库里边进行设置,就要在哪一个库里边进行验证。
- 创建用户时,我们需要指定用户名、用户密码和用户角色,用户角色表示了该用户的权限。
3.1 创建root管理员账号
[root@along ~]# mongo
mongodb shell version v4.0.5 connecting to: mongodb://127.0.0.1:27017/?gssapiservicename=mongodb implicit session: session { "id" : uuid("a36d4d10-be27-4848-981a-8fca29a57dea") } mongodb server version: 4.0.5 > show dbs #查询数据库,因为没有权限,所以不显示数据库 --- 创建root管理员用户 > use admin switched to db admin > db.createuser({user:"root",pwd:"along",roles:["root","useradminanydatabase"]}) successfully added user: { "user" : "root", "roles" : [ "root", "useradminanydatabase" ] } --- 认证登录root用户,返回1认证登录成功 > db.auth("root","along") 1 > show users #查看创建用户 { "_id" : "admin.root", "user" : "root", "db" : "admin", "roles" : [ { "role" : "useradminanydatabase", "db" : "admin" } ], "mechanisms" : [ "scram-sha-1", "scram-sha-256" ] } > show dbs #查询数据库 admin 0.000gb config 0.000gb local 0.000gb > exit bye
3.2 具体角色注解
user表示用户名,pwd表示密码,role表示角色,db表示这个用户应用在哪个数据库上。用户的角色,有如下几种:
角色名 | 意义 |
---|---|
read | 允许用户读取指定数据库 |
readwrite | 允许用户读写指定数据库 |
dbadmin | 允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile |
useradmin | 允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户 |
clusteradmin | 只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。 |
readanydatabase | 只在admin数据库中可用,赋予用户所有数据库的读权限 |
readwriteanydatabase | 只在admin数据库中可用,赋予用户所有数据库的读写权限 |
useradminanydatabase | 只在admin数据库中可用,赋予用户所有数据库的useradmin权限 |
dbadminanydatabase | 只在admin数据库中可用,赋予用户所有数据库的dbadmin权限。 |
root | 只在admin数据库中可用。超级账号,超级权限 |
3.3 再次登录认证
(1)在登入后认证
[root@along ~]# mongo
> show dbs #没有权限报错 2018-12-28t14:49:11.832+0800 e query [js] error: listdatabases failed:{ "ok" : 0, "errmsg" : "command listdatabases requires authentication", "code" : 13, "codename" : "unauthorized" } : _geterrorwithcode@src/mongo/shell/utils.js:25:13 mongo.prototype.getdbs@src/mongo/shell/mongo.js:124:1 shellhelper.show@src/mongo/shell/utils.js:876:19 shellhelper@src/mongo/shell/utils.js:766:15 @(shellhelp2):1:1 > use admin #认证,因为在admin下面添加的帐号,所以要到admin下面验证。 switched to db admin > db.auth("root","along") #认证成功 1 > show dbs admin 0.000gb config 0.000gb local 0.000gb
(2)在登录时直接认证
[root@along ~]# mongo -u "root" -p "along" --port=27017
> show dbs admin 0.000gb config 0.000gb local 0.000gb
4、mongodb增删改查操作
4.1 数据库的增删改查
> use test #有则切换,无则新增 switched to db test > show dbs #查看所有数据库 admin 0.000gb config 0.000gb local 0.000gb > db #查看当前库 test > db.test.insert({"name":"along"}) #在test库中插入一些数据,show dbs才能显示test库 writeresult({ "ninserted" : 1 }) > show dbs admin 0.000gb config 0.000gb local 0.000gb test 0.000gb > db.dropdatabase() #删除当前所在数据库 { "dropped" : "test", "ok" : 1 } > show dbs admin 0.000gb config 0.000gb local 0.000gb
4.2 集合(表)的增删查
4.2.1 mongodb 创建集合
(1)语法格式:
db.createcollection(name, options)
(2)参数说明:
- name: 要创建的集合名称
- options: 可选参数, 指定有关内存大小及索引的选项
options 可以是如下参数:
字段 | 类型 | 描述 |
---|---|---|
capped | 布尔 | (可选)如果为 true,则创建固定集合。固定集合是指有着固定大小的集合,当达到最大值时,它会自动覆盖最早的文档。 当该值为 true 时,必须指定 size 参数。 |
autoindexid | 布尔 | (可选)如为 true,自动在 _id 字段创建索引。默认为 false。 |
size | 数值 | (可选)为固定集合指定一个最大值(以字节计)。 如果 capped 为 true,也需要指定该字段。 |
max | 数值 | (可选)指定固定集合中包含文档的最大数量。 |
在插入文档时,mongodb 首先检查固定集合的 size 字段,然后检查 max 字段。
4.2.2 查询、删除集合
(1)查询集合
show collections
(2)语法格式:
db.collection.drop()
返回值:如果成功删除选定集合,则 drop() 方法返回 true,否则返回 false。
4.2.3 实例演示
在 test 数据库中创建 runoob 集合:
> use test switched to db test > db.createcollection("runoob") { "ok" : 1 }
如果要查看已有集合,可以使用 show collections 命令:
> show collections runoob
下面是带有几个关键参数的 createcollection() 的用法:
创建固定集合 mycol,整个集合空间大小 6142800 kb, 文档最大个数为 10000 个。
> db.createcollection("mycol", { capped : true, autoindexid : true, size : 6142800, max : 10000 } ) { # 不推荐使用autoindexid选项,将来的版本中将删除该选项 "note" : "the autoindexid option is deprecated and will be removed in a future release", "ok" : 1 }
在 mongodb 中,你不需要创建集合。当你插入一些文档时,mongodb 会自动创建集合。
> db.mycol2.insert({"name" : "along"}) > show collections mycol mycol2 runoob
接着删除集合 mycol2 :
> show collections mycol mycol2 runoob > db.mycol2.drop() true > show collections mycol runoob
4.3 文档(记录)的增改查删
4.3.1 mongodb 插入文档
文档的数据结构和json基本一样。
所有存储在集合中的数据都是bson格式。
bson是一种类json的一种二进制形式的存储格式,简称binary json。
(1)mongodb 使用 insert() 或 save() 方法向集合中插入文档,语法如下:
db.collection_name.insert(document)
(2)实例演示
以下文档可以存储在 mongodb 的 test 数据库 的 col 集合中:
> db.col.insert({title: 'along', description: 'mongodb 是一个 nosql 数据库', by: 'along', url: 'http://www.along.com', tags: ['mongodb', 'database', 'nosql'], likes: 100 })
以上实例中 col 是我们的集合名,如果该集合不在该数据库中, mongodb 会自动创建该集合并插入文档。
查看已插入文档:
> db.col.find() { "_id" : objectid("5c25d58627b8706e05692b0f"), "title" : "along", "description" : "mongodb 是一个 nosql 数据库", "by" : "along", "url" : "http://www.along.com", "tags" : [ "mongodb", "database", "nosql" ], "likes" : 100 }
我们也可以将数据定义为一个变量,如下所示:
> document=({title: 'along2', description: 'mongodb 是一个 nosql 数据库', by: 'along', url: 'http://www.runoob.com', tags: ['mongodb', 'database', 'nosql'], likes: 100 });
执行后显示结果如下:
{ "title" : "along2", "description" : "mongodb 是一个 nosql 数据库", "by" : "along", "url" : "http://www.runoob.com", "tags" : [ "mongodb", "database", "nosql" ], "likes" : 100 } > db.col.insert(document) writeresult({ "ninserted" : 1 })
执行插入操作:
> db.col.insert(document) writeresult({ "ninserted" : 1 }) > > db.col.find() { "_id" : objectid("5c25d7ac27b8706e05692b15"), "title" : "along", "description" : "mongodb 是一个 nosql 数据库", "by" : "along", "url" : "http://www.along.com", "tags" : [ "mongodb", "database", "nosql" ], "likes" : 100 } { "_id" : objectid("5c25d7be27b8706e05692b16"), "title" : "along2", "description" : "mongodb 是一个 nosql 数据库", "by" : "along", "url" : "http://www.runoob.com", "tags" : [ "mongodb", "database", "nosql" ], "likes" : 100 }
4.3.2 mongodb 改文档
mongodb 使用 update() 和 save() 方法来更新集合中的文档。接下来让我们详细来看下两个函数的应用及其区别。
(1)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,
下一篇: python实现三维拟合的方法