当前位置: 首页 > news >正文

【JS逆向基础】数据库之MongoDB

前言:接下来要介绍的这个数据库MongoDB,使用的人员远没有前面两个数据库使用的频率高,所以这里就简单介绍一下他的用法,有兴趣的朋友可以在官网上面搜索其使用文档进行详细的学习。

1 MongoDB简介

一般爬虫使用的数据库,是根据项目来定的。如需求方指定了使用什么数据库、如果没指定,那么决定权就在爬虫程序员手里,如果自选的话,mysal 和mongodb 用的都是比较多的。但不同的数据库品种有各自的优缺点,不同的场景任何一种数据库都可以用来存储,但是某种可能会更好。比如如果抓取的数据之间的耦合性很高,关系比较复杂的话,那么mysal可能会是更好的选择。如果抓取的数据是分版块的,并且它们之间没有相似性或关联性不强,那么可能mongodb 会更好。mongoDB的生态、理念非常先进而且成熟、但是mongoDB不仅有开源版本,还有企业版本。所以有部分公司比较担心,哪天无法使用mongoDB了,所以也会产生一些替代产品。

2 查看文档

(1)比较运算
# SQL:≡,!≡,>,<,>=,<=
# MongoDB:(key:va1ue}代表什么等于什么,"$ne","$gt","$1t","gte","1te”,其中"$ne"能用于所有数据类型
#1、select *from db.user where name ="张三";db.user.find({'name':'张三'})
#2、select *from db.user where name !"alex";db.user.find({'name':{"$ne":'张二'r) )
#3、select*from db.user where age>30;db.user.find({'age':{'$gt':30}})(2)逻辑运算
# SOL:and,or,not
# MongoDB:字典中运号分隔的多个条件是and关系,"$or"的条件放到[]内,"$not"
db.user.find({'age':{"$gte":20,"$lt":33}})
db.user.find({"addr.city":"青岛","age":{"$gt":30}})
db.user.find({"$or":[{"addr.city":"青岛"},{"age":{"$gt":30}}]
})
#4、select *from dbl.user where id号 2=l;db.user.find({'age':{"$mod":[2,1]}})
#5、上题,取反
db.user.find( {'age':{"$not":{"$mod":[2,1]}}})(3)成员运算
# SQL:in,not in
# MongoDB:"$in","$nin"
db.user.find({"age":{"$in":[20,30,40南})
db.user.find({"name":{"$nin":['张三','']}})(4)正则匹配
# SQL:regexp 正则
# MongoDB:/正则表达/i
db.user.find({'name':/^张,*/i})(5)取指定字段
db.user.find({'name':/^张,*/i},{' id':0,'name':l,'age':l})(6)查询数组
#查看有dancing爱好的人
db.user.find({'hobbies':'dancing'})
# 查看既有dancing爱好又有tea爱好的人
db.user.find({"hobbies":{"$all":['music','dancing']}
})(7)排序
#排序:--1代表升序,-1代表降序
db.user.find().sort({"name":l,})
db.user.find().sort({"age":-1,' id':1})
(8)分页
#分页:--limit代表取多少个document,skip代表跳过前多少个document
db.user.find().limit(1).skip(2)
(9)查询数量
# 获取数量
db.user icount({'age':{"$gt":30}})
--或者
db.user.find({'age':{"$gt":30}}).count()
(10)其它
# 查找所有
db.user.find()#等同于db.user.find({})
db.user.find().pretty()
#3、查找一个,与fina用法一致,只是只取匹配成功的第一个
db.user.findone({" id":{"$gt":3}})

3 更新文档

  • update:update的对象和一些更新的操作符(如$,$inc...等,相当于set后面的
  • upsert:可选,默认为false,代表如果不存在update的记录不更新也不插入,设置为true代表插入
  • multi:可选,默认为false,代表只更新找到的第一条记录,设为true,代表更新找到的全部记录。
  • writeConcern :可选,抛出异常的级别。

更新操作是不可分割的:若两个更新同时发送,先到达服务器的先执行,然后执行另外一个,不会破坏文档。

(1)覆盖更新
#注意:除非是删除,否则 id是始终不会变的
#1 :
db.user.update({'age':20},{"name" :"xxx"})是用{" id":2,“name":"xxx"}覆盖原来的记录
#2、一种最简单的更新就是用一个新的文档完全替换匹配的文档。这适用于大规模式迁移的情况。例如
var obj=db.user.findone({"namè":"张三"})
obj.name=obj.name+'先生
obj.age++
delete obj.hobbies
db.user.update({"nmae":"张三"},obj)(2)局部更新
#设置:$set
通常文档只会有一部分需要更新。可以使用原子性的更新修改器,指定对文档中的某些字段进行更新。更新修改器是种特殊的键,用来指定复杂的更新操作,比如修改、增加后者删除
db.user .update( {'name' : "xxx"},{"$set": {"name" :"apple",}} )
# 没有匹配成功则新增一条{"upsert":true}
db.user.update( {'name' :"eric"},{"$set":("name" :"eirc","age":18}},{"upsert":true))
# 默认只改匹配成功的第一条,{"multi":改多条}
db.user.update({'age':{"$gt":20}},{"$set":{"age":18}})db.user.update({'age':{"$gt":20}},{"$set":{"age":18}},{"multi":true) )
#把名字为alex的人的地2个爱好改成piao
db.user.update( {'name':"朱七"},{"$set": ("hobbies.1":"swimming" }})
#6、删除alex的爱好,Sunset
db.user.update({'name':"朱七"},{"$unset":{"hobbies" :""}})(3)自增或自减
#增加和减少:$inc
#1、所有人年龄增加一岁
db.user.update({},
{"sinc":{"age":1}
},
{"multi":true 
}
)#2、所有人年龄减少5岁
db.user.update({},
{"$inc":{"age":-5}
},
{"multi":true
}
)(4)添加删除数组内元素
#添加删除数组内元素:$push,$pop,$pu11
往数组内添加元素:push
# 为名字为朱七添加一个爱好pingpong
db.user.update( {"name":"yuanhao"},{"$push": {"hobbies":"pingpong"}} )
# 按照条件删除元素,:"$pu11”把符合条件的统统删掉,而$pop只能从两端删
db.user.update({'addr.country':"china"},{"$pull":{"hobbies":"read"}}
{"multi":true
})(5)避免重复添加
#避免添加重复:"$addToset"
db.urls.insert({" id":1,"urls":[ ]} )
db.urls.update( {" id":1},{"$addToSet": {"urls" :'http://www.baidu.com'}} )
db.urls .update( {" id" :1},{"$addToSet": {"urls" :'http://www.baidu.com'}} )
db.urls.update({" id":1},{"$addToset": {"urls":'http://www.baidu.com'}})
db.urls.update({" id":1},{"$addToSet":{"urls":{"seach":['http://www.baidu.com','http://www.baidu.com',"http://www.xxxx.com"]}}})

4 删除文档

删除文档
#1、删除多个中的第一个
db.user.deleteone({'age':8})
#2、删除国家为china的全部
db.user.deleteMany({'addr.country':'china'})
#3、删除全部
db.user.deleteMany({})
http://www.lryc.cn/news/594529.html

相关文章:

  • Django接口自动化平台实现(四)
  • SpringBoot的配置文件
  • 测试学习之——Pytest Day4
  • WPF学习笔记(28)Interaction.Triggers的意义与使用方式
  • 人工智能之数学基础:随机实验、样本空间、随机事件
  • 均值漂移累积监测算法(MDAM):原理、命名、用途及实现
  • 爬虫实战案例(两个)
  • 【Lua】大G表
  • Linux 基本指令详解
  • 【论文研读】SlowFast Networks for Video Recognition
  • 大语言模型调用方式与函数调用
  • 从磁记录到数据中心:磁盘原理与服务器架构的完整技术链路
  • CVE-2022-41128
  • 六边形滚动机器人cad【7张】三维图+设计书明说
  • 从零搭建智能搜索代理:LangGraph + 实时搜索 + PDF导出完整项目实战
  • 【超越VGGT】π3-利用置换等变方法去除3r系列的归纳偏置
  • TypeScript 中替代 Interface 的方案
  • 一文速通《二次型》
  • UE5多人MOBA+GAS 26、为角色添加每秒回血回蓝(番外:添加到UI上)
  • 图的表示法以及实现
  • zabbix服务器告警处理
  • 【windows 终端美化】Windows terminal + oh-my-posh 来美化命令行终端
  • C++ 桶排序、基数排序、堆排序
  • Beamer-LaTeX学习(教程批注版)【6】
  • selenium4 web自动化测试
  • 对LLM某一层进行优化:通过眼动数据发现中间层注重语句内在含义,进而对中间层参数优化
  • 《拆解WebRTC:NAT穿透的探测逻辑与中继方案》
  • Flink高频考点:Checkpoint与Savepoint的高可用实战指南
  • 【详细笔记】两类曲线积分转换
  • PostgreSQL 字段类型速查与 Java 枚举映射