做公司网站,哪个程序用的多/推广注册app拿佣金
1. 什么是MongoDB
1.1. 基本概念
MongoDB是一个基于分布式文件存储 [1] 的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式(MongoDB存储的是BSON文档),因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
上面说到,MongoDB是介于关系型数据库和非关系型数据库之间的产品,其实更多的人把MongoDB直接当成关系数据库,其实这都不重要,重要的是我们需要搞清楚关系型数据库如:Mysql。非关系型数据库如:Redis和MongDB他们的区别以及使用场景
高性能: 数据写入内存即完成,持久化到硬盘的操作在后台异步完成。同时副本集的读写分离,分片模式的多写可以更大程度的提高吞吐量
高可用: 副本集模式会将数据同步在一到多个副本服务器,并支持故障自动转移,同时提供了数据的冗余备份,提高了数据的可用性, 保证了数据的安全性
1.2. 数据的存储
对于数据管理来说,Mysql关系型数据库的数据是存储到磁盘的,每次进行数据的读写都涉及到IO操作,它以二维表的方式来展现数据,可以很方便的描述对象以及对象之间的关系。它的性能瓶颈就是IO造成的高并发读写能力较弱。
而对于MongoDB而言,它的数据其实是存储到磁盘上的,所有要操作的数据都是通过mmap(内存映射文件)的方式映射到内存中,数据的操作就基于这片内存进行处理的,避免了磁盘的零碎操作,性能也是非常高的。当然mmap中的数据会flush到磁盘上。
Mysql通过二维表的方式来存储数据,支持索引,事务等,MongoDB 的文件存储是BSON格式【BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON】类似JSON,相对于JSON有更快的遍历速度,而且数据类型更多。查询功能比较强大,能存储海量数据,但是不支持事务
mmap 是一种内存映射文件的方法,即将一个文件或者其它对象映射到进程的地址空间,实现文件磁盘地址和进程虚拟地址空间中一段虚拟地址的一一对映关系。实现这样的映射关系后,进程就可以采用指针的方式读写操作这一段内存,而系统会自动回写页面到对应的文件磁盘上,即完成了对文件的操作而不必再调用 read、write 等系统调用函数。相反,内核空间对这段区域的修改也直接反映用户空间,从而可以实现不同进程间的文件共享
2.MongoDB的概念
SQL术语/概念 | MongoDB术语/概念 | 解释/说明 |
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
table joins | 表连接,MongoDB不支持 | |
primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
2.1. 数据库database
一个mongodb中可以建立多个数据库,默认数据库为"db",数据库存储在data目录中,不同的数据库也放置在不同的文件中,数据库也通过名字来标识。
MongoDB默认保留了几个数据库:
- admin : admin数据库则主要存储MongoDB的用户、角色等信息。
- local : local数据库主要存储副本集的元数据,它只会在本地存储数据
- config : 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息。
2.2. 文档document
通常一个对象可以映射成一个文档,文档是一组键值(key-value)对(即 BSON,类似于JSON)。MongoDB 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大的区别,也是 MongoDB 非常突出的特点。比如在数据库中的2行数据:
id | username | age |
1 | zs | 19 |
2 | ls | 19 |
在MongoDB中的体现
{"_id" : ObjectId("605d9a0b4d99251c4e70bd6d"),"username" : "zs","id" : "1","age" : 19,"title" : "ls"
}
{"_id" : ObjectId("605d9a0b4d99251c4e70bd6e"),"username" : "ls","id" : "2","age" : 19
}
2.3. 集合collections
一个集合包含一堆 MongoDB 文档,如果把Mysql中的一行数据当做一个文档,一张表格就相当于是MongoDB中的集合
集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都会有一定的关联性。
3. 命令操作数据库和集合
创建数据库:use 数据库名 - 如果数据库不存在,则创建并切换到该数据库,存在则切换到该数据库删除数据库:先切换到数据库,然后使用db.dropDatabase()删除
创建集合:db.createCollection(集合名/表名)查看所有集合:show collections删除集合:db.集合名.drop()
添加数据:db.集合名.insert({bson格式}) - 其实可以直接添加数据,自动创建集合
修改数据:使用update()和save()方法来更新集合中的文档save()如果有_id就是修改,没有就是添加
删除数据:db.集合名.remove({bson格式})
查询数据:db.集合名.find(query)如果不传query就是查询所有如果传递了query就是按条件查询,格式也是bson格式
4.MongoDB的权限管理
4.1. 内置角色
在MongDB中内置了一些用户角色roles:
编号 | 说明 | 角色 |
1 | 数据库用户角色 | read,readWrite |
2 | 数据库管理角色 | dbAdmin,dbOwner,userAdmin |
3 | 集群管理角色 | clusterAdmin,clusterManager,clusterMonitor,hostManager |
4 | 备份恢复角色 | backup,restore |
5 | 所有数据库角色 | readAnyDatabase,readWriteAnyDatabase,userAdminAnyDatabase,dbAdminAnyDatabase |
6 | 超级用户角色 | root |
下面是每一种角色的解释
编号 | 角色 | 解释 |
1 | read | 允许用户读取指定数据库 |
2 | readWrite | 允许用户读写指定数据库 |
3 | dbAdmin | 允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile |
4 | userAdmin | 允许用户向system.users集合写入,可以向指定数据库里创建、删除和管理用户 |
5 | clusterAdmin | 只在admin数据库中可用,具有所有分片和复制集相关函数的管理权限。 |
6 | readAnyDatabase | 只在admin数据库中可用,具有所有数据库的读权限 |
7 | readWriteAnyDatabase | 只在admin数据库中可用,具有所有数据库的读写权限 |
8 | userAdminAnyDatabase | 只在admin数据库中可用,具有所有数据库的userAdmin权限 |
9 | dbAdminAnyDatabase | 只在admin数据库中可用,具有所有数据库的dbAdmin权限。 |
10 | root | 只在admin数据库中可用。超级账号,超级权限 |
4.2. 命令创建管理员账号
windows中,cmd命令窗口,输入mongo切换到mongodb的命令窗口。查看数据库
> show dbs
# 只显示有集合的数据库
切换admin数据库
> use admin
查看用户
> show users
# 只显示当前数据库的用户
创建超级用户
db.createUser(
{user: "root",pwd: "123456",roles: [ { role: "root", db: "admin" } ]
} )
# user : 用户名
# pwd : 密码
# roles : 角色
# db : 数据库
开启认证,修改配置文件 bin/mongod.cfg
,增加如下内容
security:authorization: enabled
修改之后,重启mongdb服务 ,重新连接mongdb
5.springBoot集成Mongodb
5.1.直接使用MongoTemplate
第一步:创建项目导入基础依赖,SpringBoot和MongoDB
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
第二步:yml配置mongodb
spring:data:mongodb:uri: mongodb://root:123456@127.0.0.1:27017/blog?authSource=admin&authMechanism=SCRAM-SHA-1#uri: mongodb://用户名:密码@127.0.0.1:27017/数据库?authSource=admin&authMechanism=SCRAM-SHA-1 #注意这里用户名密码要写管理员账号,写用户账号不能操作数据
第三步:配置实体类,pringData提供了@Document注解来标记文档对象
@Data
@Document(collection = "article")//实体类对应mongodb的表/文档article
public class BlogArticle {@Id //对应mongodb的表的_id,添加时不设置_id会自动增长private String _id;private Integer id;//文章名称@Field(name = "name",targetType = FieldType.STRING)private String username;//文章标签@Field(name = "age",targetType = FieldType.INT32)private Integer age;//文章简介private String address;private String tel;
}
第四步:注入MongoTemplate直接调用其API
常用api
//1.查询所有template.findAll(BlogArticle.class).forEach(System.out::println);//2.通过id查询单个System.out.println(template.findById("63a92c4b2682f13e9b06472a", BlogArticle.class));//3.通过条件查询单个:如果有多条数据只返回第一条Query query = new Query(Criteria.where("articleName").is("测试数据1-博客名"));System.out.println(template.findOne(query, BlogArticle.class));//4.通过条件查询所有符合条件的数据:返回ListQuery query = new Query(Criteria.where("articleName").is("测试数据1-博客名"));template.find(query, BlogArticle.class).forEach(System.out::println);//5.查询满足条件的总条数:查询articleName为"测试数据1-博客名"并且articleState为1的文档数量Query query = new Query(Criteria.where("articleName").is("测试数据1-博客名").and("articleState").is(1));System.out.println(template.count(query, BlogArticle.class));//2//6.分页查询:查询第二页的数据Integer currentPage = 2;Integer pageSize = 3;Query query = new Query();template.find(query.skip((currentPage - 1) * pageSize).limit(pageSize),BlogArticle.class).forEach(System.out::println);//7.模糊查询Criteria criteria = new Criteria();//以*任意字符开始,以*任意字符结尾,忽略大小写Pattern compile = Pattern.compile("^.*" + "博客" + ".*$", Pattern.CASE_INSENSITIVE);//文章名正则匹配criteria.and("articleName").regex(compile);Query query = new Query(criteria);template.find(query,BlogArticle.class).forEach(System.out::println);
5.2.实现MongoRepository
第一步:实现MongoRepository,自定义方法
/*** 持久化接口: 评论Comment*/
@Repository //将当前接口的实例交给Spring管理 - service注入使用
public interface CommentRepository extends MongoRepository<Comment,String> {/*** 根据文章id查询文章的所有评论* findBy是一种语法格式,ArticleId不能写错,.必须要与Comment实体的字段对应* @param articleId* @return*/List<Comment> findByArticleId(Long articleId);
}
第二步:注入MongoRepository实现类使用
6.MongoRepository实现分页查询
@Overridepublic Object queryPage(ArticleMongoQuery query) {//文章对象Comment comment = new Comment();//查询条件comment.setArticleId(query.getArticleId());comment.setCreateTime(null);//设置mongo查询条件Example<Comment> example = Example.of(comment, ExampleMatcher.matching().withIgnorePaths("createTime"));//设置分页条件(mongo默认从第0页开始)Pageable pageRequest = PageRequest.of(query.getCurrentPage()-1, query.getPageSize());Page<Comment> all = commentRepository.findAll(example, pageRequest);return all;}
相关文章:

Springboot集成MongoDb快速入门
1. 什么是MongoDB 1.1. 基本概念 MongoDB是一个基于分布式文件存储 [1] 的数据库。由C语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数…...

DERT目标检测—End-to-End Object Detection with Transformers
DERT:使用Transformer的端到端目标检测 论文题目:End-to-End Object Detection with Transformers 官方代码:https://github.com/facebookresearch/detr 论文题目中包括的一个创新点End to End(端到端的方法)简单的理解就是没有使…...

软件后端开发速度慢的科技公司老板有没有思考如何破局
最近接到两个科技公司咨询,说是他们公司后端开发速度太慢,前端程序员老等着,后端程序员拖了项目进度。 这种问题不只他们公司,在软件外包公司中,有一部分项目甲方客户要得急,以至于要求软件开发要快&#…...

开放原子超级链内核XuperCore可搭建区块链
区块链是一种分布式数据库技术,它以块的形式存储数据,并使用密码学方法保证数据的安全性和完整性。 每个块包含一定数量的交易信息,并通过加密链接到前一个块,形成一个不断增长的链条。 这种设计使得数据在网络中无法被篡改,因为任何尝试修改一个块的数据都会破坏整个链的…...

【Qualcomm】高通SNPE框架的使用 | 原始模型转换为量化的DLC文件 | 在Android的CPU端运行模型
目录 ① 激活snpe环境 ② 设置环境变量 ③ 模型转换 ④ run on Android 首先,默认SNPE工具已经下载并且Setup相关工作均已完成。同时,拥有原始模型文件,本文使用的模型文件为SNPE 框架示例的inception_v3_2016_08_28_frozen.pb文件。imag…...

C++map与set
文章目录 前言一、map和set基础知识二、set与map使用示例1.set去重操作2.map字典统计 总结 前言 本章主要介绍map和set的基本知识与用法。 一、map和set基础知识 map与set属于STL的一部分,他们底层都是是同红黑树来实现的。 ①set常见用途是去重 ,set不…...

随手记:前端一些定位bug的方法
有时候接到bug很烦躁,不管是任何环境的bug,看到都影响心情,随后记总结一下查看bug的思路,在摸不着头脑的时候或者焦虑的时候,可以静下心来顺着思路思考和排查bug可能产生的原因 1.接到bug,最重要的是&am…...

【深度学习】03-神经网络2-1损失函数
在神经网络中,不同任务类型(如多分类、二分类、回归)需要使用不同的损失函数来衡量模型预测和真实值之间的差异。选择合适的损失函数对于模型的性能至关重要。 这里的是API 的注意⚠️,但是在真实的公式中,目标值一定是…...

Python爬虫APP程序:构建智能化数据抓取工具
在信息爆炸的时代,数据的价值日益凸显。Python作为一种强大的编程语言,与其丰富的库一起,为爬虫程序的开发提供了得天独厚的优势。本文将探讨如何使用Python构建一个爬虫APP程序,以及其背后的思维逻辑。 什么是Python爬虫APP程序&…...

第五部分:2---中断与信号
目录 操作系统如何得知哪个外部资源就绪? 什么是中断机制? CPU引脚和中断号的关系: 中断向量表: 信号和中断的关系: 操作系统如何得知哪个外部资源就绪? 操作系统并不会主动轮询所有外设来查看哪些资源…...

梧桐数据库(WuTongDB):SQL Server Query Optimizer 简介
SQL Server Query Optimizer 是 SQL Server 数据库引擎的核心组件之一,负责生成查询执行计划,以优化 SQL 查询的执行性能。它的目标是根据查询的逻辑结构和底层数据的统计信息,选择出最优的查询执行方案。SQL Server Query Optimizer 采用基于…...

Scrapy框架介绍
一、什么是Scrapy 是一款快速而强大的web爬虫框架,基于Twusted的异步处理框架 Twisted是事件驱动的 Scrapy是由Python实现的爬虫框架 ① 架构清晰 ②可扩展性强 ③可以灵活完成需求 二、核心组件 Scrapy Engine(引擎):Scrapy框架…...

Facebook对现代社交互动的影响
自2004年成立以来,Facebook已经成为全球最大的社交媒体平台之一,改变了人们的交流方式和社交互动模式。作为一个数字平台,Facebook不仅为用户提供了分享生活点滴的空间,也深刻影响了现代社交互动的各个方面。本文将探讨Facebook如…...

Java项目运维有哪些内容?
Java项目运维的内容主要包括环境准备、部署Java应用、配置和优化、安全配置、以及数据安全保护措施,服务的运行和资源动态监控管理。 1,环境准备:这包括选择适合运行Java和Tomcat的操作系统,如Ubuntu、CentOS等Linux发行版…...

【学习笔记】MIPI
MIPI介绍 MIPI是由ARM、Nokia、ST、IT等公司成立的一个联盟,旨在把手机内部的接口如存储接口,显示接口,射频/基带接口等标准化,减少兼容性问题并简化设计。 MIPI联盟通过不同的工作组,分别定义一系列手机内部的接口标…...

QMake 脚本知识点记录
1. 简单工程配置 QT core guigreaterThan(QT_MAJOR_VERSION, 4): QT widgetsCONFIG c11CONFIG debug # debug/release HEADERS demo.h # 头文件 列表 SOURCES main.cpp demo.cpp # 源文件 列表 FORMS mainwin.ui # 窗体 列表…...

Kubernetes配置管理(kubernetes)
实验环境: 在所有节点上拉取镜像;然后把资源清单拉取到第一个master节点上; 同步会话,导入镜像: configmap/secret 配置文件的映射 变量: 基于valuefrom的方式 cm--》pod 特点:变量的名称可…...

macOS与Ubuntu虚拟机使用SSH文件互传
1.ubuntu配置: 安装openssh服务: sudo apt-get install openssh-server -y 查看服务启动状态: systemctl status ssh 2.macOS使用scp连接ubuntu并发送文件 查看ubuntu IP : ifconfigmacOS终端连接ubuntu : sc...

defineExpose 显式导出子组件方法
当父组件调用子组件的script setup中的方法时,必须显式导出该方法。因为 script setup 中定义的变量和方法默认是局部的,只有显式导出后,父组件才能访问这些方法。 //父组件-Parent <template><el-button type"primary" …...

vue 解决列表界面进入明细返回查询条件不变
在Vue中,如果你遇到了列表界面进入详情页面后返回查询条件不变的问题,可能是因为你没有正确地管理状态或者是使用了不合适的组件间通信方式。 解决方案通常涉及到以下几点: 使用Vuex来管理状态,确保查询条件保存在全局状态树中&…...

华为NAT ALG技术的实现
双向NAT技术:经过防火墙的2报文源IP地址和目的IP地址都同时被转换,外网发送报文给内网服务器,先转换目的IP地址,然后符合安全策略后,在替换源IP地址,然后将记录写入防火墙会话表,并发送出报文&a…...

【移植】轻量系统STM32F407芯片移植案例
往期知识点记录: 鸿蒙(HarmonyOS)应用层开发(北向)知识点汇总 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~ 持续更新中…… 介绍基于 STM32F407IGT6 芯片在拓维信息 Niobe407 开发板上移植 Op…...

k8s 修炼手册
deployment apiVersion: apps/v1 kind: Deployment metadata:name: hello-deploy spec:replicas: 10selector:matchLabels:app: hello-world # Pod的label # 这个Label与Service的Label筛选器是匹配的revisionHistoryLimit: 5progressDeadlineSeconds: 300minReadySeconds: 10…...

重回1899元,小米这新机太猛了
如果不出意外,距离高通年度旗舰骁龙 8 Gen4 发布还剩下不到一个月时间。 对于以小米 15 为首即将到来的下半年各家旗舰机型厮杀画面,讲道理小忆早已是备好瓜子儿摆上果盘翘首以盼了。 不过在这之前,中端主流选手们表示有话要说:为…...

jmeter本身常用性能优化方法
一、常用配置: 修改Jmeter.bat文件,调整JVM参数(修改jmeter本身的最小最大堆内存),默认都是1个G set HEAP-Xms5g -Xmx5g -XX:MaxMetaspaceSize256m我的本机内存是8G,那最大可以设置870%(本机内存的70%) 这里我设置的5g 如果有…...

Vue3中el-table组件实现分页,多选以及回显
el-table组件实现分页,多选以及回显 需求思路1、实现分页多选并保存上一页的选择2、记录当前选择的数据3、默认数据的回显 完整代码 需求 使用 dialog 显示 table,同时关闭时销毁el-table 表格多选回显已选择的表格数据,分页来回切换依然正确…...

柯桥韩语学校|韩语每日一词打卡:회갑연[회가변]【名词】花甲宴
今日一词:회갑연 韩语每日一词打卡:회갑연[회가변]【名词】花甲宴 原文:인구 노령화에 따라서 요즘 회갑연보다는 고희연을 더 많이 지냅니다. 意思:随着人口老龄化,最近比起花甲宴,更多人办古稀宴。 【原文分解】 1、인구[인구]…...

python概述
目录 python语言的特点 python语言的优点: python语言的缺点: 1.常用的python编辑器 PyCharm Jupyter Notebook VScode 模块的安装、导入与使用 安装 导入与使用 python语言的特点 1.简洁 2.语法优美 3.简单易学 4.开源:用户可自…...

使用celery+Redis+flask-mail发送邮箱验证码
Celery是一个分布式任务队列,它可以让你异步处理任务,例如发送邮件、图片处理、数据分析等。 在项目中和celery 有关系的文件如下: task.py : 创建celery.py 对象,并且添加任务,和app绑定,注意࿱…...

【第十四章:Sentosa_DSML社区版-机器学习之时间序列】
目录 【第十四章:Sentosa_DSML社区版-机器学习时间序列】 14.1 ARIMAX 14.2 ARIMA 14.3 HoltWinters 14.4 一次指数平滑预测 14.5 二次指数平滑预测 【第十四章:Sentosa_DSML社区版-机器学习时间序列】 14.1 ARIMAX 1.算子介绍 考虑其他序列对一…...