NoSQL学习二:MongoDB基本管理命令
MongoDB命令学习
一、MongoDB命令帮助
在安装MongoDB后,启动服务器进程(mongod),可以通过在客户端命令mongo实现对MongoDB的管理和监控:
这是MongoDB最上层的命令列表,主要是管理数据库的:数据库操作帮助、集合操作帮助、管理帮助。如果想了解数据库操作更详细的命令,可以直接使用db.help(),如下所示:
二、基本命令
1、show dbs
2、use pagedb
3、show collections
4、db.serverStatus()
5、查询指定数据库统计信息
三、基本DDL和DML
3.1 数据库操作
- 切换、创建数据库
use yourDB
- 查询所有数据库
show dbs
- 删除当前使用数据库
db.dropDatabase()
- 从指定主机上克隆数据库
db.cloneDatabase("127.0.0.1")
- 从指定的机器复制数据库数据到某个数据库
db.copyDatabase("mydb","temp","127.0.0.1")
- 修复数据库
db.repairDatabase()
- 查看当前使用的数据库
db.getName
或db
- 显示当前数据库状态
db.stats()
- 当前db版本
db.version()
- 查看当前数据库机器地址
db.getMongo()
3.2 集合操作
- 创建集合
db.createCollection('collName',{size:20,capped:5,max:100})
创建成功会显示{"ok":1}
- 得到指定名称的集合
db.getCollection("account")
- 得到当前数据库所有集合
db.getCollectionNames()
- 得到当前数据库所有集合索引的状态
db.printCollectionStats()
3.3 用户相关
- 添加用户
db.addUser("name")
和db.addUser("userName","pwd123",true)
设置密码、是否只读 - 数据库认证
db.auth("userName","123123")
- 显示当前所用用户
show users
- 删除用户
db.removeUser("userName")
3.4 集合查询
- 查询所用记录
db.userInfo.find()
默认每页显示20条记录 - 查询去掉后的当前集合中的某列的重复数据
db.userInfo.disinct("name")
- 等于
db.userInfo.find({"gae":22})
查询age==22的集合 - 大于
db.userInfo.find({"age":{$gt:22}})
- 小于
db.userInfo.find({"age":{$lt:22}})
- 包含
db.userInfo.find({name:/mongo/})
- 开头
db.userInfo.find({name:/^mongo/})
- 查询指定列name、age
db.userInfo.find({},{name:1,age:1})
- 查询指定数据
db.userInfo.find({age:{$gt25}},{name:1,age:1})
- 升序
db.userInfo.find().sort({age:1})
- 降序 db.userInfo.find().sort({age:-1})
- 查询前5条数据
db.userInfo.find().limit(5)
- 查询10条以后的数据
db.userInfo.find().skip(10)
- 查询5-10条数据
db.userInfo.find().limit(10).skip(5)
- 与查询
db.userInfo.find({$or:[{age:22},{age:25}]})
- 查询第一条数据
db.userInfo.findOne()
- 查询集合的条数
db.userInfo.find().count()
- 按某列进行排序
db..find({sex:{$exists:true}}).count()
- group db.userInfo.group({"key": {"age": true},"initial": {"user": []},reduce": function(cur,prev){prev.user.push(cur.name);}
参数选项:1.key: 这个就是分组的key 2.initial: 每组都分享一个初始化函数,特别注意:是每一组initial函数。 3.reduce: 这个函数的第一个参数是当前的文档对象,第二个参数是上一次function操作的累计对象。有多少个文档, $reduce就会调用多少次。 4.condition: 这个就是过滤条件。 5.finalize: 这是个函数,每一组文档执行完后,多会触发此方法。
3.5 索引
- 添加索引 db.users.ensureIndex({"name":1}) ensureIndex方法参数中,数字1表示升序,-1表示降序。
- 唯一索引 db.users.ensureIndex({"name":1},{"unique":true})
- 组合索引 db.users.ensureIndex({"name":1, "age":-1})
- 查看索引 db.users.getIndexes()
- 查询索引 db.users.find({"name":"k"}).hint({"name":1,"age":1})
- 删除索引 db.users.dropIndexes()
- 删除指定索引 db.users.dropIndex("name_1")
NoSQL学习二:MongoDB基本管理命令的更多相关文章
- MongoDB基本管理命令 [转]
MongoDB基本管理命令 linux下配置安装mongodb 10分钟玩转mongoDB 官网安装教程 使用命令行方式连接mongodb: mongo /admin -u用户名 -p密码 --连接 ...
- Linux学习之常用权限管理命令(二)
(一)常用权限管理命令 (1)chmod命令 (2)chown (3)chgrp (4)umask (一)常用权限管理命令 (1)chmod命令 命令名称:chmod命令英文原意:change the ...
- MongoDB基本管理命令
MongoDB是一个NoSQL数据库系统:一个数据库可以包含多个集合(Collection),每个集合对应于关系数据库中的表:而每个集合中 可以存储一组由列标识的记录,列是可以自由定义的,非常灵活,由 ...
- EF Codefirst 初步学习(二)—— 程序管理命令 更新数据库
前提:搭建成功codefirst相关代码,参见EF Codefirst 初步学习(一)--设置codefirst开发模式 具体需要注意点如下: 1.确保实体类库程序生成成功 2.确保实体表类库不缺少 ...
- Redis教程(十二):服务器管理命令总结
转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/140.html 一.概述: Redis在设计之初就被定义为长时间不间断运行 ...
- Linux命令(二十七) 用户组管理命令
Linux提供了一系列的命令管理用户组.用户组就是具有相同特征的用户集合.每个用户都有一个用户组,系统能对一个用户组中所有用户进行集中管理,通过把相同属性的用户定义到同一用户组,并赋予该用户自一定的操 ...
- Oracle的学习二:表管理(数据类型、创建/修改表、添加/修改/删除数据、数据查询)
1.Oracle表的管理 表名和列名的命名规则: 必须以字母开头: 长度不能超过30个字符: 不能使用oracle的保留字: 只能使用如下字符:A-Z, a-z, 0-9, $, # 等. Oracl ...
- Linux命令(二十三) 磁盘管理命令(一) df,du,tune2fs
一. 查看磁盘占用空间情况 df df 命令用于查看硬盘空间的使用情况,还可以查看硬盘分区的类型或 inode 节点的使用情况等. df 命令常用参数如下: -a 显示所有文件系统的磁盘使用情况,包括 ...
- mongodb常见管理命令
----------1.复制数据库 wind:PRIMARY> show dbs; jinri 0.078GB local 1.078GB test 0.078GB wind 0.078GB w ...
随机推荐
- My安卓知识2--使用listview绑定sqlite中的数据
我想在我的安卓项目中实现一个这样的功能,读取sqlite数据库中的数据并显示到某个页面的listview控件中. 首先,我建立了一个Service类,来实现对数据库的各种操作,然后在这个类中添加对数据 ...
- Java Web1
Java Web应用的核心技术是Java Server Page和Servlet.此外,开发一个完整的Java Web应该涉及一下几种概念及技术. 1.Servlet组件 Servlet响 ...
- 【extjs】:获取列名,时间转换
1.日期字符戳转时间 renderer : function(value, arg2) { if (value != null && value != ' ...
- SEO是企业发展的永恒主题
最近接触很多客户问同一个问题,明明自己的网站花的时间很多,界面设计的很美,该考虑到的优化都考虑了,反而我那么优秀的网站却不如一个自己行业里的一个垃圾网站排名高,我没排名而对方的排名却很高?我每天坚持更 ...
- .net 微信分享功能
微信在国内目前无疑是最火的社交软件,智能手机装机必备. 微信api有java,php,Python语言的demo, 为毛没有C#的范例?兄长今天给各位带来一个.不叫哥(割)了,A股今天又暴跌[3912 ...
- python第一天基础1-1
win下是没有多进程的 windows:1.下载安装包 https://www.python.org/downloads/2.安装 默认安装路径:C:\python273.配置环境变量 [右键计算机] ...
- STM32之PWM波形输出配置总结
一. TIMER分类: STM32中一共有11个定时器,其中TIM6.TIM7是基本定时器:TIM2.TIM3.TIM4.TIM5是通用定时器:TIM1和TIM8是高级定时器,以及2个看门狗定时器 ...
- PHP那些非常有用却鲜有人知的函数
PHP里有非常丰富的内置函数,很多我们都用过,但仍有很多的函数我们大部分人都不熟悉,可它们却十分的有用.这篇文章里,我列举了一些鲜为人知但会让你眼睛一亮的PHP函数. levenshtein() 你有 ...
- 一个日期的下一个星期五 next_date
select next_day('18-5月-2001','星期五') nxt_day from dual;
- Oracle查看用户操作sql语句以及数据库日志
--查看日志文件 select member from v$logfile; --查看表空间使用情况 SELECT SUM(bytes) / (1024 * 1024) AS free_space, ...