6、MongoDB基本使用(mongodb使用场景 简书)
wptr33 2025-05-02 13:50 14 浏览
Mongodb
Mongodb优势
基础命令
管理
备份
恢复
数据库命令
集合命令
存储的数据
数据查询
数据增加
数据更新
数据删除
高级查询
比较运算符
范围运算符
或者
正则表达式
常用方法
自定义查询
返回指定的字段
排序
统计
去重
索引
创建索引
单利索引
联合索引
删除索引
查看索引
Python操作Mongodb
Mongodb
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组,它是一种非关系的数据库Nosql。
那么非关系带来的一个问题就是,耗存储空间,就比如10000条数据,每条数据都有一条是一样的,那么在关系型数据库的情况下,我们就可以直接使用外键的方式来进行存储,那么对于mongodb这样的非关系型数据库就需要每一条数据都进行存储,带来一定的资源浪费;
在关系型数据库下,扩展性比较差,如果我们开始定义了一些数据,后期想要改起来非常麻烦,而且在大数据下IO比较大,因为我们要查询一条数据出来可能需要连很多表才能把这个数据给完整展现出来。那对Mongodb来说,它解决这个问题就非常简单,因为它是菲关系的,数据和数据之间没有任何关联,不涉及到连表查询,同时打来的好处就是速度快,灵活性比较好,不需要预先为表做字段,直接插即可;
Mongodb优势
易扩展性:NoSQL数据库种类繁多,但是一个共同的特点就是去掉关系型数据库的关系特性,数据之间无关系,这样就非常易于扩展;
性能高:在大数据量的情况下表现优秀,NoSQL数据库都具有非常搞的读写性能,尤其是在大数据量下,这得益于它的无关系性,数据库结构简单;
灵活性:NoSQL无需事先为要存储的数据建立字段,随时可以存储自定义的数据格式,而在关系型数据库里,增删字段是一见非常麻烦的事情;
基础命令
管理
管理包含数据备份和恢复;
备份
mongodump -h dbHost -d dbName -o backupDir
恢复
mongorestore -h dbHost -d dbName --dir backupDir
数据库命令
show dbs:查看库;
use:切换数据库;
db:查看当前数据库;
db.dropDatabase():删除当前数据库;
集合命令
show collections:查看当前数据库的所有集合;
db.集合名称.drop():删除集合;
db.createCollection("cce"):创建一个集合;
存储的数据
Object ID:文档ID;
每个文档都有一个_id,保证文档的唯一性,如果没有显示定义,那么mongodb会自动生成;
Sting:字符串,必须是有效的utf8;
Boolean:存储一个布尔类型,true或false;
Integer:整形可以是32位或者64位;
Double:存储浮点数;
Arrays:数组或者列表,多个值存储到一个文档;
Object:用于嵌入式的文档,即一个值为一个文档;
Null:存储null值;
Timestamp:时间戳;
Date:存储当前时间或者时间的unix格式;
创建日期的语句:new Date('2018-01-15') # 需要传入一个时间;
数据查询
db.集合名称.find():查找指定的数据,如果没有给定查询条件,默认查询所有, db.caichangen.find({"age":18})这是一个给定条件的示例;
数据增加
db.caichangen.insert({"name":"cce","age":18}) # 增加一条数据{"name":"cce","age":18}) # 如果数据已存在那么会抛出错误;
db.caichangen.save({"name":"cce","age":18}) # 增加一条数据{"name":"cce","age":18}) # 如果已存在就更新,如果不存在那么就插入;
数据更新
语法:db.集合名称.update(<query>,<update>,{multi:<boolean>})
更新一条数据:db.caichangen.update({},{age:30}) | db.caichangen.update({},{$set:{age:30}})
条件更新:db.caichangen.update({age:20},{age:30})
批量更新:db.caichangen.update({age:20},{$set:{age:30}},{multi:true})
数据删除
语法:db.集合名称.remove(<query>,{justOne:<Boolean>})
query:查询条件;
justOne:布尔值,为true删除一条,默认false删除所有数据;
删除匹配条件的所有:db.caichangen.remove({age:30},{justOne:false})
高级查询
find:查询,可以在后面加上pretty()将结果格式化;
findOne:查询,返回第一个集合,可以在后面加上pretty()将结果格式化;
比较运算符
等于:默认是等于判断,没有运算符;
$lt:小于;
$lte:小于等于;
$gt:大于;
$gte:大于等于;
$ne:不等于;
语法:db.caichangen.find({age:{$lt:18}})
范围运算符
$in:是否在某个范围内;
$nin:是否在某个范围内;
语法:db.caichangen.find({age:{$in:[18,19]}})
或者
and:并且;
$or:值为数组,数组中每个元素为json;
语法:db.caichangen.find({$or:[{age:18},{name:"cce"}]})
查询姓名为cce或者cfj并且年龄是18的:db.caichangen.find({$or:[{name:"cfj"},{name:"cce"}],age:18})
正则表达式
使用//或者$regex编写正则表达式;
语法:
db.caichangen.find({name:/^c/})
db.caichangen.find({name:{$regex:'e#39;}})
常用方法
limit:限制返回指定数量的文档;
db.caichangen.find().limit(Number)
skip:用于跳过指定数量的文档;
db.caichangen.find().skip(Number)
同时使用:
db.caichangen.find().limit(Number).skip(Number)
自定义查询
使用$where后面写一个函数,返回满足条件的数据;
示例:
db.caichangen.find({$where:function(){return this.age>30;}})
返回指定的字段
语法:db.集合名称.find({},{字段:0/1}) # 0不显示,1显示;
示例:
db.caichangen.find({name:{$regex:'e#39;}},{age:1,_id:0})
排序
sort:sort可以在返回结果集后进行排除处理,传入一个1或者-1,1升序,-1降序;
示例:
db.caichangen.find().sort({age:1})
统计
count:可以对结果集进行统计,也可以直接统计集合;
示例:
db.caichangen.find().count()
db.caichangen.count({age:{$gt:20}})
去重
distinct:可以对结果集进行去重;
语法:
db.集合名称.distinct('去重字段':{条件})
示例:
db.stu.distinct('age':{age:{$gt:18}})
索引
建立索引提升查询速度,默认情况下mongodb会自动将_id字段设置为索引;
创建索引
单利索引
测试:插入10万条数据到数据库中
for(var i=0;i<100000;i++){db.caichangen.insert({name:"cce"+i,age:i})}
测试:
db.caichangen.find({'name':'cce10000'}) # 测试查询
db.caichangen.find({'name':'cce10000'}).explain('executionStats') # 查看上面查询语句的执行状态信息,executionTimeMillis是查询时间;
创建索引:
语法:db.集合名称.ensureIndex({属性:1/-1}) # 1表示升序,-1表示降序,-1的使用场景是经常使用sort来操作数据;
示例:db.caichangen.ensureIndex({name:1})
联合索引
语法:db.集合名称.ensureIndex({属性:1/-1,属性:1/-1})
删除索引
语法:db.集合名称.dropIndex('索引名称')
查看索引
语法:db.集合名称.getIndexs()
Python操作Mongodb
安装:pip install pymongo
from pymongo import MongoClient
client = MongoClient(host='192.168.1.254', port=27017) # 初始化一个client对象,拿到一个连接初始化信息
collection = client['cce']['caichangen'] # 指定要连接的库和集合
# 清空数据库
collection.drop()
# 插入单条数据
date = {"_id": 1, "name": "cce0", "age": 100}
collection.insert(date)
# 插入多条数据
data_many=[{"name": "name" + str(1000+i), 'age': i} for i in range(10)] # 创建数据
collection.insert_many(data_many) # 多条插入
# 查询所有数据
result=collection.find({'name':'cce0'}) # 返回一个游标对象,它是一个可迭代对象,当游标走到最后的时候那么就获取不到数据了,和我们的生成器一样;
for i in result:
print(i)
# 查询一条数据
result=collection.find_one({'name':'cce0'})
print(i)
# 更新一条数据
collection.update_one({'name':'cce0'},{"$set":{'name':'caichangen'}})
# 更新所有数据
collection.update_many({'name':'cce0'},{"$set":{'name':'caichangen'}})
相关推荐
- SQL轻松入门(5):窗口函数(sql语录中加窗口函数的执行)
-
01前言标题中有2个字让我在初次接触窗口函数时,真真切切明白了何谓”高级”?说来也是一番辛酸史!话说,我见识了窗口函数的强大后,便磨拳擦掌的要试验一番,结果在查询中输入语句,返回的结果却是报错,Wh...
- 28个SQL常用的DeepSeek提示词指令,码住直接套用
-
自从DeepSeek出现后,极大地提升了大家平时的工作效率,特别是对于一些想从事数据行业的小白,只需要掌握DeepSeek的提问技巧,SQL相关的问题也不再是个门槛。...
- 从零开始学SQL进阶,数据分析师必备SQL取数技巧,建议收藏
-
上一节给大家讲到SQL取数的一些基本内容,包含SQL简单查询与高级查询,需要复习相关知识的同学可以跳转至上一节,本节给大家讲解SQL的进阶应用,在实际过程中用途比较多的子查询与窗口函数,下面一起学习。...
- SQL_OVER语法(sql语句over什么含义)
-
OVER的定义OVER用于为行定义一个窗口,它对一组值进行操作,不需要使用GROUPBY子句对数据进行分组,能够在同一行中同时返回基础行的列和聚合列。...
- SQL窗口函数知多少?(sql窗口怎么执行)
-
我们在日常工作中是否经常会遇到需要排名的情况,比如:每个部门按业绩来排名,每人按绩效排名,对部门销售业绩前N名的进行奖励等。面对这类需求,我们就需要使用sql的高级功能——窗口函数。...
- 如何学习并掌握 SQL 数据库基础:从零散查表到高效数据提取
-
无论是职场数据分析、产品运营,还是做副业项目,掌握SQL(StructuredQueryLanguage)意味着你能直接从数据库中提取、分析、整合数据,而不再依赖他人拉数,节省大量沟通成本,让你...
- SQL窗口函数(sql窗口函数执行顺序)
-
背景在数据分析中,经常会遇到按某某条件来排名、并找出排名的前几名,用日常SQL的GROUPBY,ORDERBY来实现特别的麻烦,有时甚至实现不了,这个时候SQL窗口函数就能发挥巨大作用了,窗...
- sqlserver删除重复数据只保留一条,使用ROW_NUMER()与Partition By
-
1.使用场景:公司的小程序需要实现一个功能:在原有小程序上,有一个优惠券活动表。存储着活动产品数据,但因为之前没有做约束,导致数据的不唯一,这会使打开产品详情页时,可能会出现随机显示任意活动问题。...
- SQL面试经典问题(一)(sql经典面试题及答案)
-
以下是三个精心挑选的经典SQL面试问题及其详细解决方案,涵盖了数据分析、排序限制和数据清理等常见场景。这些问题旨在考察SQL的核心技能,适用于初学者到高级开发者的面试准备。每个问题均包含清晰的...
- SQL:求连续N天的登陆人员之通用解答
-
前几天发了一个微头条:...
- SQL四大排序函数神技(sql中的排序是什么语句)
-
在日常SQL开发中,排序操作无处不在。当大家需要排序时,是否只会想到ORDERBY?今天,我们就来揭秘SQL中四个强大却常被忽略的排序函数:ROW_NUMBER()、RANK()、DENSE_RAN...
- 四、mysql窗口函数之row_number()函数的使用
-
1、窗口函数之row_number()使用背景窗口函数中,排序函数rank(),dense_rank()虽说都是排序函数,但是各有用处,假如像上章节说的“同组同分”两条数据,我们不想“班级名次”出现“...
- ROW_NUMBER()函数(rownumber函数与rank区别)
-
ROW_NUMBER()是SQL中的一个窗口函数(WindowFunction)...
- Dify「模板转换」节点终极指南:动态文本生成进阶技巧(附代码)Jinja2引擎解析
-
这篇文章是关于Dify「模板转换」节点的终极指南,解析了基于Jinja2模板引擎的动态文本生成技巧,涵盖多源文本整合、知识检索结构化、动态API构建及个性化内容生成等六大应用场景,助力开发者高效利用模...
- Python 最常用的语句、函数有哪些?
-
1.#coding=utf-8①代码中有中文字符,最好在代码前面加#coding=utf-8②pycharm不加可能不会报错,但是代码最终是会放到服务器上,放到服务器上的时候运行可能会报错。③...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
git 执行pull错误如何撤销 git pull fail
-
面试官:git pull是哪两个指令的组合?
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)