代码编织梦想

一、下载数据库

MongoDB数据库官方下载

二、安装数据库

安装过程中,你可以通过点击 “Custom(自定义)” 按钮来设置你的安装目录,但我们选择第一个选项就行
在这里插入图片描述

在这里插入图片描述

三、启动数据库
  1. 打开cdm命令窗口,输入 mongod 启动数据库;
  2. 如果输入指令后显示 不是内部或者外部命令,那么就是mongodb数据库的环境变量有问题,你需要去配置一下环境变量,找到mongodb数据库的安装地址,然后复制它bin目录的地址,然后添加到环境变量;
  3. 然后在cdm命令窗口,输入 mongod 启动数据库。然后你还需要在C盘的根目录下创建一个data文件夹,data文件夹里面创建一个db文件夹,不然启动会报错。
  4. 另外打开一个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常用查询语句
  1. 查询所有记录
    db.userInfo.find();
    相当于:select* from userInfo;

  2. 查询去掉后的当前聚集集合中的某列的重复数据
    db.userInfo.distinct(“name”);
    会过滤掉 name 中的相同数据
    相当于:select distict name from userInfo;

  3. 查询 age = 22 的记录
    db.userInfo.find({“age”: 22});
    相当于: select * from userInfo where age = 22;

  4. 查询 age > 22 的记录
    db.userInfo.find({age: {$gt: 22}});
    相当于:select * from userInfo where age >22;

  5. 查询 age < 22 的记录
    db.userInfo.find({age: {$lt: 22}});
    相当于:select * from userInfo where age <22;

  6. 查询 age >= 25 的记录
    db.userInfo.find({age: {$gte: 25}});
    相当于:select * from userInfo where age >= 25;

  7. 查询 age <= 25 的记录
    db.userInfo.find({age: {$lte: 25}});

  8. 查询 age >= 23 并且 age <= 26 注意书写格式
    db.userInfo.find({age: {$gte: 23, $lte: 26}});

  9. 查询 name 中包含 mongo 的数据 模糊查询用于搜索
    db.userInfo.find({name: /mongo/});
    //相当于%%
    select * from userInfo where name like ‘%mongo%’;

  10. 查询 name 中以 mongo 开头的
    db.userInfo.find({name: /^mongo/});
    select * from userInfo where name like ‘mongo%’;

  11. 查询指定列 name、age 数据
    db.userInfo.find({}, {name: 1, age: 1});
    相当于:select name, age from userInfo;
    当然 name 也可以用 true 或 false,当用 ture 的情况下河 name:1 效果一样,如果用 false 就
    是排除 name,显示 name 以外的列信息。

  12. 查询指定列 name、age 数据, age > 25
    db.userInfo.find({age: {$gt: 25}}, {name: 1, age: 1});
    相当于:select name, age from userInfo where age >25;

  13. 按照年龄排序 1 升序 -1 降序
    升序:db.userInfo.find().sort({age: 1});
    降序:db.userInfo.find().sort({age: -1});

  14. 查询 name = zhangsan, age = 22 的数据
    db.userInfo.find({name: ‘zhangsan’, age: 22});
    相当于:select * from userInfo where name = ‘zhangsan’ and age = ‘22’;

  15. 查询前 5 条数据
    db.userInfo.find().limit(5);
    相当于:selecttop 5 * from userInfo;

  16. 查询 10 条以后的数据
    db.userInfo.find().skip(10);
    相当于:select * from userInfo where id not in (
    selecttop 10 * from userInfo
    );

六、mongodb可视化工具

Robo T3 下载地址
MongoDBCompass 官方下载地址

七、使用mongoose连接数据库

mongoose 中文文档

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接: https://blog.csdn.net/Y_one/article/details/111060349

Win10系统 MongoDB 4.4.2 安装教程及相关配置-爱代码爱编程

Win10系统 MongoDB 4.4.2 安装教程及相关配置 最近正好在使用MongoDB数据库,发现网上很多安装教程说的不明不白,所以打算自己写一下MongoDB的安装教程。方便以后在开发中使用到时作为参考安装教程。一起来看看如何安装MongoDB 呢~ 最新版本直接去 MongoDB 的官网下载: 点这里访问MongoDB 的官网 不过国内用户

MyBatis内置DataSource的连接池实现原理-爱代码爱编程

前言 MyBatis是一个流行的ORM框架,它简单易用,支持自定义SQL、存储过程以及高级映射。MyBatis免除了几乎所有的JDBC代码以及设置参数和获取结果集的工作。 作为一款优秀的持久层框架,连接池是必不可少的。本文将分析MyBatis内置的数据源是如何实现连接池功能的(源码基于MyBatis3.4.5)。 JDBC对数据库的操作 回忆一下,我

Oracle基础使用-体系结构+表空间、用户、表的管理+使用scott用户+多表查询子查询-爱代码爱编程

Oracle 1. oracle介绍 ORACLE 数据库是目前世界上使用最为广泛的数据 库管理系统,作为一个通用的数据库系统,它具有完整的数据管理功能 作为一个关系数据库, 它是一个完备关系的产品 作为分布式数据库它实现了分布式处理功能 2.oracle体系结构 2.1数据库Database 数据库是数据的物理存储,包括数据文件ORA、

今日份知识分享:SQL 介绍-爱代码爱编程

SQL 是什么? SQL 是用于访问和处理数据库的标准的计算机语言。 SQL,指结构化查询语言,全称是 Structured Query Language。 SQL 让您可以访问和处理数据库。 SQL 是一种 ANSI(American National Standards Institute 美国国家标准化组织)标准的计算机语言。 SQL

数据库--oracle--如何在Ubuntu上安装Oracle-爱代码爱编程

写在前面: 下面的内容是国外的一篇教程,我跟着做了一遍,没有什么问题,所以翻译过来供大家参考。 环境: oracle12c ubuntu18.04(我是在Ubuntu16.04上装的,也没什么问题) 正文: 欢迎你!这篇教程会教你如何一步步地在Ubuntu18.04服务器上安装Oracle12c R2数据库。这篇教程中包含所有你必须要执行的命令

php学生成绩管理系统,数据库使用MySQL,包括源代码和数据库SQL文件,具有学生和教师登录管理功能-爱代码爱编程

php学生成绩管理系统,数据库使用MySQL,包括源代码和数据库SQL文件,具有学生和教师登录管理功能 数据库SQL文件 /* Navicat Premium Data Transfer Source Server : localhost Source Server Type : MySQL Source Server

Win10系统 MongoDB 4.4.2 安装教程及相关配置-爱代码爱编程

Win10系统 MongoDB 4.4.2 安装教程及相关配置 最近正好在使用MongoDB数据库,发现网上很多安装教程说的不明不白,所以打算自己写一下MongoDB的安装教程。方便以后在开发中使用到时作为参考安装教程。一起来看看如何安装MongoDB 呢~ 最新版本直接去 MongoDB 的官网下载: 点这里访问MongoDB 的官网 不过国内用户

CentOS7 安装 MongoDB-爱代码爱编程

将下载的安装包上传到服务器mongodb-linux-x86_64-rhel70-4.4.2.tgz /opt/soft路径下,这里需要注意的是一定要选择小版本号是偶数的版本,因为奇数版是开发的版本,不适合应用在生产环境。解压tar -xzvf mongodb-linux-x86_64-rhel70-4.4.2.tgz 将文件移动到/usr/local

模糊查询——MongoDB-爱代码爱编程

MongoDB的模糊查询是使用正则匹配实现:关键操作符**$regex** 1.MongoDB 使用 $regex 操作符来设置匹配字符串的正则表达式。 2.MongoDB使用PCRE (Perl Compatible Regular Expression) 作为正则表达式语言。 当要实现MongoDB的document中某字段内容模糊查询时,可以在

【完结】java基于vue,MongoDB的随机点名带头像功能-爱代码爱编程

今天突发奇想,结合之前前后端分离项目,做出一个随机点名小程序,结果中涂调了5个小时(我太菜了) 话不多数正式开始,首先是后端代码,基本和上一篇博客差别不大 【总结】基于Vue,springboot,MongoDB的简单前后端分离, 只是加了一个img属性,真正存还是在项目static下。 第一版前端代码,首先不能用size去查看数组大小, var

MongoDB的详细安装过程-爱代码爱编程

1.从官网上下载mongodb。 https://www.mongodb.com/try/download/community?tck=docs_server 2.以下是我下载的。 3.点击complete直接,然后直接下一步。 4.接下来是配置mongodb数据库的数据文件和日志文件了,我们要手动为mongodb创建数据文件和日志文件,这两个文件可以放在

mongoose中findOneAndUpdate()方法-爱代码爱编程

// 执行修改操作 const task = await Task.findOneAndUpdate({_id: req.body._id}, _.pick(req.body, ['title', 'completed']),{new: true}) //findOneAndUpdate()默认返回原始的数据 //其中{_id: req.body._id}