MongoDB 是一个开源的 NoSQL 数据库,它可以用来存储大量的数据,并且可以快速地进行读写操作。要使用 MongoDB,首先需要连接到 MongoDB 服务器。MongoDB 连接命令是 mongo,它可以用来连接到 MongoDB 服务器。
mongo --host<:port> -u -p
上面的命令中,--host 参数用于指定 MongoDB 服务器的主机名或 IP 地址;-u 参数用于指定登录 MongoDB 服务器的用户名;-p 参数用于指定登录 MongoDB 服务器的密码。如果不想使用密码登录,可以省略 -p 参数。
mongo --host localhost:27017 -u admin -p mypassword
上面的命令将会使用 admin 用户名和 mypassword 密码连接到本地 27017 端口上的 MongoDB 服务器。如果想要使用其他端口连接本地机器上的 MongoDB 服务器,也可以修改端口号来达到目的。
在本教程我们将讨论MongoDB的不同连接方式。
在前面的教程中,我们已经讨论了如何启动MongoDB服务,你只需要在MongoDB安装目录的bin目录下执行"mongod"即可。
执行启动操作后,mongodb在输出一些必要信息后不会输出任何信息,之后就等待连接的建立,当连接被建立后,就会开始打印日志信息。
你可以使用MongoDB shell 来连接 MongoDB 服务器。你也可以使用PHP来连接mongodb。本教程我们会使用 MongoDB shell来连接Mongodb服务,之后的章节我们将会介绍如何通过php 来连接MongoDB服务。
默认情况下,MongoDB的启动端口为27017。比MongoDB启动端口大1000的端口为MongoDB的web用户界面,你可以在浏览器中输入http://localhost:28017 来访问MongoDB的web用户界面。
你可以通过执行以下命令来连接MongoDB的服务。
mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
标准的连接格式包含了多个选项(options),如下所示:
选项 | 描述 |
---|---|
replicaSet=name | 验证replica set的名称。 Impliesconnect=replicaSet. |
slaveOk=true|false |
|
safe=true|false |
|
w=n | 驱动添加 { w : n } 到getLastError命令. 应用于safe=true。 |
wtimeoutMS=ms | 驱动添加 { wtimeout : ms } 到 getlasterror 命令. 应用于 safe=true. |
fsync=true|false |
|
journal=true|false | 如果设置wie true, 同步到 journal (在提交到数据库前写入到实体中). 应用于 safe=true |
connectTimeoutMS=ms | 可以打开连接的时间。 |
socketTimeoutMS=ms | 发送和接受sockets的时间。 |
使用默认端口来连接 MongoDB 的服务。
mongodb://localhost
通过 shell 连接 MongoDB 服务:
$ ./mongo
MongoDB shell version: 4.0.9
connecting to: test
...
这时候你返回查看运行 ./mongod 命令的窗口,可以看到是从哪里连接到MongoDB的服务器,您可以看到如下信息:
……省略信息……
2015-09-25T17:22:27.336+0800 I CONTROL [initandlisten] allocator: tcmalloc
2015-09-25T17:22:27.336+0800 I CONTROL [initandlisten] options: { storage: { dbPath: "/data/db" } }
2015-09-25T17:22:27.350+0800 I NETWORK [initandlisten] waiting for connections on port 27017
2015-09-25T17:22:36.012+0800 I NETWORK [initandlisten] connection accepted from 127.0.0.1:37310 #1 (1 connection now open) # 该行表明一个来自本机的连接
……省略信息……
使用用户名和密码连接到 MongoDB 服务器,你必须使用 "username:password@hostname/dbname" 格式,"username"为用户名,"password" 为密码。
使用用户名和密码连接登录到默认数据库:
$ ./mongo
MongoDB shell version: 4.0.9
connecting to: test
使用用户 admin 使用密码 123456 连接到本地的 MongoDB 服务上。输出结果如下所示:
> mongodb://admin:123456@localhost/
...
使用用户名和密码连接登录到指定数据库,格式如下:
mongodb://admin:123456@localhost/test
连接本地数据库服务器,端口是默认的。
mongodb://localhost
使用用户名admin,密码123456登录localhost的admin数据库。
mongodb://admin:123456@localhost
使用用户名admin,密码123456登录localhost的数据库。
mongodb://admin:123456@localhost/
连接两个 replica pair的服务器, 服务器1为example1.com服务器2为example2.com。
当使用两个数据库,其中一个作为备份数据库时,需要一个复制机制来实现读写分离方案和节点(数据库)同步,replica pair则是MongoDB的一种复制机制。
mongodb://example1.com:27017,example2.com:27017
连接三台replica set 的服务器 (端口 27017, 27018, 和27019):
与replica pair类似,replica set也是一种复制机制,而且可以算是replica pair的进阶版,因为replica pair只能在两个节点间同步,而replica set解决了这个问题。
mongodb://localhost,localhost:27018,localhost:27019
连接三台 replica set 的服务器, 写入操作应用在主服务器 并且分布查询到从服务器。
mongodb://host1,host2,host3/?slaveOk=true
直接连接第一个服务器,无论是replica set一部分或者主服务器或者从服务器。
mongodb://host1,host2,host3/?connect=direct;slaveOk=true
当你的连接服务器有优先级,还需要列出所有服务器,你可以使用上述连接方式。
安全模式连接到localhost:
mongodb://localhost/?safe=true
以安全模式连接到replica set,并且等待至少两个复制服务器成功写入,超时时间设置为2秒。
mongodb://host1,host2,host3/?safe=true;w=2;wtimeoutMS=2000
索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录...
在本章中,我们将在访问宏的基础知识。宏是一个工具,可以让你自动执行任务和你的窗体,报表和控件添加功能。 Access中的宏与Wor...
Access中一个特别有用的格式化工具是应用条件格式,以突出显示特定数据的能力。让我们来看一个条件格式的简单例子。例子在这个例...
数据库是允许彼此逻辑关系的数据表的集合。您可以使用关系,通过它们共有的字段来连接表。一个表可以是任意数量的关系的一部分,...
SQLite 的触发器是数据库的回调函数,它会在指定的数据库事件发生时自动执行/调用。以下是关于SQLite的触发器的要点:SQLite 触...