MongoDB命令

我的博客

mongod参数说明

参数说明
dbpath数据文件存放路径,每个数据库会在其中创建一个子目录,用于防止同一个实例多次运行的 mongod.lock 也保存在此目录中。
logpath错误日志文件
logappend错误日志采用追加模式,默认是覆写模式。
bind_ip对外服务的绑定ip,一般设置为空,及绑定在本机所有可用 ip 上,如有需要可以单独指定。
port对外服务端口。Web 管理端口在这个 port 的基础上+1000。
fork以后台 Daemon 形式运行服务
maxConns最大连接数
directoryperdb每个 db 存放在单独的目录中,建议设置该参数。与 MySQL 的独立表空间类似。
repairpath执行 repair 时的临时目录。在如果没有开启 journal,异常 down 机后重启,必须执行 repair 操作。
syncdelay系统同步刷新磁盘的时间,单位为秒,默认是 60 秒。

这么多参数,全面写在命令行中则容易杂乱而不好管理。因此,mongod 支持将参数写入到 一个配置文本文件中,然后通过 config 参数来引用此配置文件:

./mongod --config /etc/mongo.cnf

数据库常用命令

# 创建数据库, 如果有则进入, 如果没有则创建
use demo_database;

# 查看所有db
show dbs;

# 从指定主机上克隆数据库
db.cloneDatabase(“127.0.0.1”);

# 修复当前db
db.repairDatabase();

# 显示当前db的状态
db.stats();

# 查看当前db的链接机器地址
db.getMongo();

# 删除当前使用的db
db.dropDatabase();

# 查看当前db的版本
db.version();

# 关闭数据库连接
shutdownServer();

集合(Collection)常用命令

集合相对于关系型数据库中的表。

// 创建一个集合, 创建成功会显示{“ok”:1}
db.createCollection(“account”, {size: 20, capped: 5, max: 100});

// 判断集合是否为定容量
db.collName.isCapped();

// 查询集合
db.getCollection("account");

// 获取当前db下的所有集合
db.getCollectionNames();
// 或者
show collections();

// 显示当前db所有聚集索引的状态
db.printCollectionStats();

其中创建集合的语法为:

db.createCollection(name, options)

name为集合的名字,options为参数(可选),指定有关内存大小和索引选项,options有以下几个选项:

字段类型描述
cappedBoolean(可选)如果为true,则启用封顶集合。封顶集合是固定大小的集合,会自动覆盖最早的条目,当它达到其最大大小。如果指定true,则需要也指定尺寸参数。
autoIndexIDBoolean(可选)如果为true,自动创建索引_id字段的默认值是false。
sizeNumber(可选)指定最大大小字节封顶集合。如果封顶如果是 true,那么你还需要指定这个字段。
maxNumber(可选)指定封顶集合允许在文件的最大数量。

用户相关的命令

# 添加用户
db.addUser("userName");
db.addUser("userName", "pwd123", true); // 用户名、密码、是否只读

# 数据库认证、安全模式
db.auth("userName", "123123");

# 查看所有的用户
show users;

# 删除用户
db.removeUser("userName");

添加、删除、修改相关

# 添加数据
db.account.save({'name': 'xigua', age: '23', 'location': 'China SH'});

# 修改数据
ab.account.update({'name': 'xigua'}, {$set: {'age': 24}}); // 相当于update account set age=24 where name=xigua

# 删除数据
db.account.remove({'name': 22});

查询相关

# 我们先插入一些数据以供查询
for (var i=1; i<100; i++) db.account.insert({'name': i, 'age': i});

# 查询所有记录,默认每页显示20条记录
db.account.find(); // account为集合名,相比于关系型数据库来说,相当于select * from account

# 设置查询时每页显示的记录数
DBQuery.shellBatchSize= 50; // 输入it 显示更多

# 过滤name字段相同的数据
db.account.distinct("name"); // 相比于关系型数据库来说,相当于select distinct name form account

# 查询name=88的记录
db.account.find({'name': 88}); // 相当于select * from account where name = 88

# 查询name>88的记录
db.account.find({'name': {$gt: 22}}); // 相当于select * from account where name > 88

# 查询name<88的记录
db.account.find({'name': {$lt: 22}}); // 相当于select * from account where name < 88

# 大于 $gt
# 小于 $lt
# 大于等于 $gte
# 小于等于 $lte

# 查询name中包含数字9的数据
db.account.find({'name': /9/});

# 查询指定列的数据
db.account.find({}, {name: 1, age: 1}); // 相当于select name, age from account 

# 按照name升序排序
db.account.find().sort({name: 1});

# 按照name降序排序
db.account.find().sort({name: -1});

# 查询name = 1, age = 1的数据
db.account.find({name: 1, age: 1}); // 相当于select * from account where name=1 and age=1;

# 查询前五条数据
db.account.find().limit(5); // 相当于select top 5 * from account

# 查询20条以后的数据
db.account.find().skip(10);

# or
db.account.find({$or: [{age: 10}, {age: 20}]}); // 相当于select * from account where age=10 or age=20;

# 查询第一条数据
db.account.findOne();

# 查询某个结果集的记录条数
db.account.find().count(); // 相当于select count(*) from account

# 查询所有结果中不包含name的记录
db.account.find({name: {$exists: false}});

# 查询所有结果中对2取模为0的数据
db.account.find({num: {$mode: [2, 0]}});

# 查询结果中num值不等于3的数据
db.account.find({num: {$ne: 3}})

# 包含$in
db.table.find({num: {$in: [1, 3, 5]}})

# 不包含$nin
db.table.find({num: {$nin: [1, 3, 5]}})

# $size 数组元素个数
# 对于{name: 'David', age: 26, favorite_number: [ 6, 7, 9 ] }记录 匹配 db.users.find({favorite_number: {$size: 3}});
# 不匹配 db.users.find({favorite_number: {$size: 2}});

# 正则匹配
db.account.find({name: {$not: /^T.*/}});

# 查看记录数
db.table.find().count();

# 从第 3 条记录开始,返回 5 条记录(limit 3, 5)
db.users.find().skip(3).limit(5);

简单的语句块操作

# 打印
print('Hello MongoDB!');

# 将一个对象转换成json
tojson(new Object());
tojson(new Object('a'));

# 循环添加数据
for (var i=1; i<100; i++) {
    db.account.insert({'name': i, 'age': i});
}

# forEach迭代循环
db.users.find().forEach(printjson);

其他

# 查询之前的错误信息
db.getPrevError();

# 清楚错误信息
db.resetError();
    原文作者:by_openwater
    原文地址: https://segmentfault.com/a/1190000006983717
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞