MongoDB数据库的环境搭建和基本使用-爱代码爱编程
一、下载数据库
二、安装数据库
安装过程中,你可以通过点击 “Custom(自定义)” 按钮来设置你的安装目录,但我们选择第一个选项就行
三、启动数据库
- 打开cdm命令窗口,输入 mongod 启动数据库;
- 如果输入指令后显示 不是内部或者外部命令,那么就是mongodb数据库的环境变量有问题,你需要去配置一下环境变量,找到mongodb数据库的安装地址,然后复制它bin目录的地址,然后添加到环境变量;
- 然后在cdm命令窗口,输入 mongod 启动数据库。然后你还需要在C盘的根目录下创建一个data文件夹,data文件夹里面创建一个db文件夹,不然启动会报错。
- 另外打开一个cmd命令窗口,输入mongo 连接数据库。
四、mongodb常用语句
1. 查询操作
查看当前数据库版本
db.version()
//4.2.2
查询所有数据库
show dbs
//admin 0.000GB
//config 0.000GB
//local 0.000GB
admin: 从权限的角度来看,这是"root"数据库。要是将一个用户添加到这个数据库,这个用户自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器。
local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合
config: 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。
显示当前数据库
db
//test
切换指定数据库
use local
//switched to db local
db
//local
查看smile数据库当前状态
db.stats()
//{ "db" : "smile", "collections" : 1, "objects" : 10000, "avgObjSize" : 80, "dataSize" : 800000, "storageSize" : 258048, "numExtents" : 0, "indexes" : 1, "indexSize" : 94208, "ok" : 1 }
查看当前数据库的连接机器地址
db.getMongo() //connection to 127.0.0.1
2. 创建和删除数据库
创建数据库
use smile
说明:当use的时候,系统就会自动创建一个数据库。如果use之后没有创建任何集合。系统就会删除这个数据库。
删除数据库
use smile
//switched to db smile
db.dropDatabase()
//{ "dropped" : "smile", "ok" : 1 }
说明:如果没有选择任何数据库,会删除默认的test数据库
3. 集合
创建集合
方法一:
db.createCollection('a')//{ "ok" : 1 }
方法二:
db.c.insert({name:'smile'});//当插入一个文档的时候,一个集合就会自动创建。
查看创建的合集
db.getCollectionNames()//[ "a", "b" ]
查看合集里的内容
db.c.find() //{ "_id" : ObjectId("5a4cbcea83ec78b7bea904f8"), "name" : "smile" } { "_id" : ObjectId("5a4cbcfc83ec78b7bea904f9"), "url" : "http://blog.nmtui.com" }
注:默认每页显示20条记录,当显示不下的的情况下,可以用it迭代命令查询下一页数据。
重命名集合
db.c.renameCollection("smile")// { "ok" : 1 }
删除合集
db.a.drop() //true
删除集合中的记录数
db.log.distinct("name") # 查询去掉当前集合中某列的重复数据 [ "mongodb" ]
db.log.remove({}) # 删除集合中所有记录
查看集合存储信息
db.log.stats() # 查看数据状态
db.log.dataSize() # 集合中数据的原始大小
db.log.totalIndexSize() # 集合中索引数据的原始大小
db.log.totalSize() # 集合中索引+数据压缩存储之后的大小
db.log.storageSize() # 集合中数据压缩存储的大小
pretty()
输出整齐排布
db.log.find({uid:1000}).pretty()
五、mongodb常用查询语句
-
查询所有记录
db.userInfo.find();
相当于:select* from userInfo; -
查询去掉后的当前聚集集合中的某列的重复数据
db.userInfo.distinct(“name”);
会过滤掉 name 中的相同数据
相当于:select distict name from userInfo; -
查询 age = 22 的记录
db.userInfo.find({“age”: 22});
相当于: select * from userInfo where age = 22; -
查询 age > 22 的记录
db.userInfo.find({age: {$gt: 22}});
相当于:select * from userInfo where age >22; -
查询 age < 22 的记录
db.userInfo.find({age: {$lt: 22}});
相当于:select * from userInfo where age <22; -
查询 age >= 25 的记录
db.userInfo.find({age: {$gte: 25}});
相当于:select * from userInfo where age >= 25; -
查询 age <= 25 的记录
db.userInfo.find({age: {$lte: 25}}); -
查询 age >= 23 并且 age <= 26 注意书写格式
db.userInfo.find({age: {$gte: 23, $lte: 26}}); -
查询 name 中包含 mongo 的数据 模糊查询用于搜索
db.userInfo.find({name: /mongo/});
//相当于%%
select * from userInfo where name like ‘%mongo%’; -
查询 name 中以 mongo 开头的
db.userInfo.find({name: /^mongo/});
select * from userInfo where name like ‘mongo%’; -
查询指定列 name、age 数据
db.userInfo.find({}, {name: 1, age: 1});
相当于:select name, age from userInfo;
当然 name 也可以用 true 或 false,当用 ture 的情况下河 name:1 效果一样,如果用 false 就
是排除 name,显示 name 以外的列信息。 -
查询指定列 name、age 数据, age > 25
db.userInfo.find({age: {$gt: 25}}, {name: 1, age: 1});
相当于:select name, age from userInfo where age >25; -
按照年龄排序 1 升序 -1 降序
升序:db.userInfo.find().sort({age: 1});
降序:db.userInfo.find().sort({age: -1}); -
查询 name = zhangsan, age = 22 的数据
db.userInfo.find({name: ‘zhangsan’, age: 22});
相当于:select * from userInfo where name = ‘zhangsan’ and age = ‘22’; -
查询前 5 条数据
db.userInfo.find().limit(5);
相当于:selecttop 5 * from userInfo; -
查询 10 条以后的数据
db.userInfo.find().skip(10);
相当于:select * from userInfo where id not in (
selecttop 10 * from userInfo
);
六、mongodb可视化工具
Robo T3 下载地址
MongoDBCompass 官方下载地址
七、使用mongoose连接数据库
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接: https://blog.csdn.net/Y_one/article/details/111060349