mongoDB操作文档(全部)

news2025/1/10 1:39:46

mongoDB

1、创建、查询数据库

创建数据库
use dade
查询数据库
show dbs

2、创建集合、查看

创建集合插入数据
db.集合名.insert({})
db.dade.insert({dade:'大得',age:18})
​
查看集合
show tables
​
查看集合中的数据
db.集合名.find()  查询所有
db.dade.find()
​
db.集合名.findOne()   查询第一个文档

3、删除集合、删除数据库

删除集合
db.集合名.drop();
​
删除数据库
use 数据库
db.dropDatabase()

4、操作符

$lt , $lte , $gt , $gte   ( < , <= , > , >= ), $ne ( <> ) ,$in , $nin ,  $or ,  $not,  
$mod (取模),  $exists, $where 

4、增、删、改、查

1、增
use dade  切换数据库
db.集合名.insert({name:’xiaobai’,spc:{weight:100,address:’guangzhou’}})
db.dade.insert({dade:'大得',age:1818})
​
2、删除
db.dade.remove({age:1818})
删除大于18的
db.dade.remove({age:{'$gt':18}})
​
3、修改
这个age大于18的修改name值,注意其他值丢失
db.dade.update({age:{'$gt':18}},{name:'修改'})
​
这个修改其他数据不丢失,修改age等于18的
db.dade.update({age:18},{'$set':{name:10}})
​
这个数据统计,如是20,+10,操作后是30
db.dade.update({age:1818},{'$inc':{name:10}})
​
4、查文档,dade是集合名
查所有
db.dade.find()
​
查第一条
db.dade.findOne();
​
查age等于18的
db.dade.find({age:18})
​
查age大于18的
db.dade.find({age:{'$gt':18}})
​
查询只拿name值,1只表示显示name值
db.dade.find({},{name:1})
​
排除age,0表示排除
db.dade.find({},{age:0})
​
升序,根据年龄升序 
db.集合名.find().sort({age:1})
​
倒序,根据年龄降序
db.集合名.find().sort({age:-1})
​
显示集合前三的文档
db.集合.find().limit(3)
​
集合分页
db.集合.find().skip(2).limit(5)
​
获得集合总条数
db.集合名.count()

5、模糊查询

/66/,/相当mysql的%
db.dade.find({dade:/66/})

6、$in查询

包含
db.dade.find({age:{'$in':[18,1818]}})
不包含
db.dade.find({age:{'$nin':[18,1818]}})

7、mongoDB账号管理

登录mongodb的客户端,使用如下命令
​
1、创建超级管理员
use  admin
db.createUser({ user:'root', pwd:'123456', roles:[{role:'root',db:'admin'}]})
​
2、修改 Mongodb 数据库配置文件,enabled开启
security:
  authorization: enabled
  
3、重启 mongodb 服务
​
​
4、创建普通账号
use dade
db.createUser( { user: "phpadmin", pwd: "123456", roles: [ { role: "dbOwner", db: "php" } ] } )
​
​
5、查看当前库下的用户
show users;
​
6、删除用户
db.dropUser("dade")
​
7、修改密码
db.updateUser( "admin",{pwd:"password"}); #修改用户密码
db.auth("admin","password"); #密码认证

8、Mongodb 数据库角色

(1)数据库用户角色:read、readWrite; 
(2)数据库管理角色:dbAdmin、dbOwner、userAdmin; 
(3)集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager; 
(4)备份恢复角色:backup、restore; 
(5)所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、 dbAdminAnyDatabase 
(6)超级用户角色:root

9、Mongodb 中索引

1、为name创建索引
db.集合名.ensureIndex({name:1})
db.集合名.ensureIndex({键名:1}) 1是升续 -1是降续
​
2、多列索引
db.集合名.ensureIndex({field1:1/-1, field2:1/-1});
​
3、子文档索引
db.集合名.ensureIndex({filed.subfield:1/-1})
​
如下文档可以建立子文档索引
{name:’诺基亚手机1’,price:12.34,spc:{weight:100,area:’纽约’}}
{name:’诺基亚手机2’,price:42.34,spc:{weight:200,area:’伦敦’}}
比如要查询weight等于100的文档。
db.goods.find({‘spc.weight’:100})
根据当前案例,我们建立子文档索引
db.集合名.ensureIndex({'spc.weight':1})
​
4、唯一索引
db.集合名.ensureIndex({name:-1},{unique:true})
​
5、查看索引
常用命令: 
(1)查看当前索引状态: db.集合名.getIndexes(); 
(2)详情查看本次查询使用哪个索引和查询数据的状态信息。
explain executionStats 查询具体的执行 时间
db.tablename.find().explain( "executionStats" ) 
关注输出的如下数值:explain.executionStats.executionTimeMillis
​
6、删除索引
删除单个索引
db.集合名.dropIndex({filed:1/-1});
​
删除所有索引
db.集合名.dropIndexes();
注意:在删除所有的索引时,主键索引会保留。
​
7、重建索引 
一个表经过很多次修改后,导致表的文件产生空洞,索引文件也如此. 
可以通过索引的重建,减少索引文件碎片,并提高索引的效率. 
类似mysql中的optimize table 
mysql里面使用optimize table语法:optimize table 表名
语法:db.集合名.reIndex() 
​
8、索引使用注意事项 
(1)创建索引的时候,注意1是正序创建索引  -1是倒叙创建索引
(2)索引的创建在提高查询性能的同时会影响插入性能,对于经常查询少插入的文档可以考虑用索引
(3)复合索引要注意索引的先后顺序。 
(4)每个键全建立索引不一定就能提高性能,索引不是万能的。
(5)在做排序工作的时候如果是超大数据量也可以考虑加上索引用来提高排序的性能。

10、Mongodb 中数据导出与导入

1、导出数据
导入/导出可以操作的是本地的mongodb服务器,也可以是远程的,所以,都有如下通用选项。
利用mongoexport 
-h host主机
--port 端口
-d 指明使用的库
-c 指明要导出的集合
-o 指明要导出的文件名
--csv指定导出的csv格式
-q 过滤导出
-f field1 field2  列名
-u username 用户名
-p password 密码
如下操作,
注意:如果端口是默认的可以不使用--port来指定端口。
比如我们要导出php库下面的Java集合,
E:\Program Files\MongoDB\Server\4.0\bin>mongoexport -h localhost -d php -c java -o e:/nihao.json -u phpadmin -p 123456
​
2、导入数据
使用mongoimport命令
-d 待导入的数据库
-c 待导入的集合(不存在会自己创建)
--type csv/json(默认) 
--file 备份文件名称包含路径
​
例1: 导入json 
./bin/mongoimport  -h  --port  端口号  -d test -c goods --file ./goodsall.json   
例2: 导入csv 
./bin/mongoimport -h  --port  端口号 -d test -c goods --type csv -f goods_id,goods_name --file ./goodsall.csv 
./bin/mongoimport -h  --port  端口号 -d test -c goods --type csv --headline -f goods_id,goods_name --file ./goodsall.csv
案例:把刚才导出的nihao.json文件导入到php库里面的user集合里面。
E:\Program Files\MongoDB\Server\4.0\bin>mongoimport -h localhost -d php -c nihao --file e:/nihao.json -u phpadmin -p 123456

11、主从复制(读写分离)

可以通过不同端口来模拟多台mongodb服务器
​
具体的配置步骤
1、启动主服务器
--port --dbpath –logpath --master
​
2、启动从服务器
--port –dbpath –logpath –slave –source 127.0.0.1:1111
​
3、客户端登陆到主服务器
添加一些数据,测试是否同步到从服务器
如下在主服务器里面,添加了一些文档
第一步:客户端登录到主服务器,添加一些文档
mongo localhost:1111
​
登陆到从服务器,查看是否有数据
mongo localhost:2222
如果有数据,则成功了

12、tp6使用mongodb

配置数据库,在数据库配置文件
'mongo'=>[ 
   'type'  =>  'mongo',  
   'hostname' => '127.0.0.1',   
   'database' => 'database',
   'username'        => '',
   'password'        => '',
   'hostport' => '27017'
]
​
新增
$res = Db::connect('mongo')->table('news')->insertGetId($data);
查询
$res = Db::connect('mongo')->table('news')->select();
单条件查询
$mangoList = Db::connect('mongo')->table('news')->where('id','76')->select();
更新
$mangoList = Db::connect('mongo')->table('news')->where('id','76')->update([
'title'=>'eeeeeeeeeee'
]);
删除
$mangoList = Db::connect('mongo')->table('news')->where('id','75')->delete();
$mangoList = Db::connect('mongo')->table('news')->where('_id','6021506535f34b1ef9497352')->delete();
​

13、php操作

插入
$mongo = new MongoClient('mongodb://localhost:27017');
$db = $mongo->mf; //选择数据库
$collection = $db->friend; //选择文档集合
$doc = [ //定义一个文档,即一个数组
'First Name' = >'Jet', 'Last Name' = >'Wu', 'Age' = >26, 'Phone' = >'110', 'Address' = >['Country' = >'China', 'City' = >'Shen Zhen'], 'E-Mail' = >['123456@qq.com', '666666@sina.com', '8888888@qq.com', '77887788@qq.com']];
$res = $collection->insert($doc);
​
查询
$mongo = new MongoClient('mongodb://localhost:27017');
$db = $mongo - >mf;
$collection = $db->friend;
$cursor = $collection->find(['Address'=>'China']);

14、php安装mongodb扩展

https://windows.php.net/downloads/pecl/releases/mongodb/

 

注意:扩展文件

下载合适的php_mongodb.dll文件。 

(1)php的版本 

(2)是否是线程安全的thread safe(ts)

(3)是vc几的 

(4)php是32位的还是64位的。

步骤:

(1)把对应的扩展,拷贝到php的安装目录里面的ext目录里面。

注意:拷贝后,改名为php_mongo.dll

(2)打开php.ini文件,引入该扩展,

(3)重启apache,

使用phpinfo()函数测试

tp6配置

安装

composer require topthink/think-mongo
// 更多的数据库配置信息
'mongo'=>[
    'type'  =>  'mongo',
    'hostname' => '127.0.0.1',
    'database' => '数据库名称',
    'username'        => '',
    'password'        => '',
    'hostport' => '27017'
]

操作篇

https://blog.csdn.net/qq_34631220/article/details/128173120?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22128173120%22%2C%22source%22%3A%22qq_34631220%22%7D

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/61939.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微服务框架 SpringCloud微服务架构 16 SpringAMQP 16.1 基本介绍

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式&#xff0c;系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 SpringCloud微服务架构 文章目录微服务框架SpringCloud微服务架构16 SpringAMQP16.1 基本介绍16.1.1 什么是SpringAMQP16 SpringAMQP 16.1 …

Android -- 每日一问:你在Android开发中遇到的技术难题是什么,你是怎么解决的?

经典回答 一个工作过几年的程序员肯定会有工作中遇到技术难点问题&#xff0c;虽然这个问题有可能对于别人不是技术难点&#xff0c;但只要对于当时的你是技术难点&#xff0c;只要让你抓耳挠腮毫无头绪就往往会在你的大脑中留下深刻的印象。 这个问题&#xff0c;我也比较难…

【三维目标检测】VoteNet(二)

VoteNet数据和源码配置调试过程请参考上一篇博文&#xff1a;【三维目标检测】VoteNet&#xff08;一&#xff09;_Coding的叶子的博客-CSDN博客。本文主要详细介绍VoteNet网络结构及其运行中间状态。 1 VoteNet模型总体过程 VoteNet核心思想在于通过霍夫投票的方法实现了端到…

[附源码]计算机毕业设计基于SpringBoot的高校课程知识库

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

1550_AURIX_TC275_锁相环的操作

全部学习汇总&#xff1a; GreyZhang/g_TC275: happy hacking for TC275! (github.com) 继续SCU模块的学习&#xff0c;这一次主要是看一下锁相环的操作。锁相环之前接触的不少了&#xff0c;其实主要的一个功能就是提升单片机的时钟主频。 1. 备份时钟其实也是稳定可靠的&…

供应荧光染料FITC-PEG-FA,Folic acid-PEG-Fluorescein,荧光素-聚乙二醇-叶酸

An English name&#xff1a;FITC-PEG-FA&#xff0c;Folic acid-PEG-Fluorescein Chinese name&#xff1a;荧光素-聚乙二醇-叶酸 Item no&#xff1a;X-GF-0247-5k CAS&#xff1a;N/A Formula&#xff1a;N/A MW&#xff1a;荧光素-聚乙二醇5-叶酸、FITC-PEG 2-FA、荧光…

使用Python和SAS Viya分析社交网络

本示例使用Python和SAS分析了预防高危药物研究的结果。这个社交网络有194个节点和273个边&#xff0c;代表药物、使用者之间的联系。最近我们被客户要求撰写关于社交网络的研究报告&#xff0c;包括一些图形和统计输出。 背景 SAS Viya的最新版本提供了用于探索实验问题的全套创…

GIT分布式版本控制系统 | 命令讲解入门

Git概述 Git是一个开源的分布式版本控制系统&#xff0c;可以有效、高速地处理从很小到非常大的项目版本管理。 也是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件&#xff1b;分布式相比于集中式的最大区别在于开发者可以提交到本地&#xff0c…

车间调度|基于帝王蝶优化算法的车间调度(Matlab代码实现)

目录 1 概述 2 蝴蝶优化算法 3 车间调度 3.1 车间调度描述 3.2 数学模型 4 运行结果 5 参考文献 6 Matlab代码实现 1 概述 随着智能化在制造业中的普及&#xff0c;解决车间生产调度的问题能有效提高车间的工作学习效率&#xff0c;实现车间现场管理的有序化、智能化…

极客时间Kafka - 01 Kafka术语|生产者|消费者|主题|分区|副本|ISR|OSR|AR|HW|LEO|Offset

文章目录1. 为什么需要消息引擎&#xff1f;2. Kafka 相关术语3. Kafka 基本概念1. 为什么需要消息引擎&#xff1f; 答案就是“削峰填谷”。 所谓的“削峰填谷”就是指缓冲上下游瞬时突发流量&#xff0c;使其更平滑。特别是对于那种发送能力很强的上游系统&#xff0c;如果没…

Java—hashCode、equals

文章目录hashCode()介绍hashCode()hashCode方法作用为什么要有hashCode()&#xff1f;equals()equals()作用&#xff1f;为什么重写equals方法必须重写hashcode方法&#xff1f;128陷阱&#xff1f;equals和hashCode的关系——————————————————————————…

前端环境变量及vite中本地环境配置实践

前言 前端在之前并没有工程化的概念&#xff0c;甚至开发环境、测试环境、生产环境全靠大家手动配置。 有了nodejs之后&#xff0c;环境变量 &#xff08;environment variables&#xff09;这个概念&#xff0c;便慢慢进入了前端的视野&#xff0c;方便了前端各种环境自动化…

Android背景和音乐

Android背景和音乐前言一、添加背景图片二、加入背景音乐前言 简单的给app添加背景图和音乐 一、添加背景图片 准备好一张合适的背景图片新建一个Empty Activity项目选择Java语言在res中创建一个mipmap文件,将准备的图片粘贴到该文件目录下 在activity_main.xml里面添加代码…

mysql高阶语句

目录 前言 一、高级sql语句 1、按关键字排序 二、区间判断 ——且/或 三、 distinct 查询不重复记录 四、对结果进行分组 五、限制结果条目——limit 六、设置别名&#xff08;alias ——>as&#xff09; 七、通配符 八、子查询 前言 当我们对mysql数据库进行了查…

GJB 5000B二级-QA质量保证

1、主要变化情况 修订2条,合并1条(绿色),新增1条(黄色) 新增的主要内容 将原标准过程域名称“过程和产品质量保证”改为“质量保证” 目的:评价并改进已执行的过程和所产生的工作产品的质量,确保其满足已制定的过程说明和适用的标准。 (GJB5000A:过程和产品质量保…

RISC-V SiFiveU64内核——L2 Prefetcher预期器

目录L2 Prefetcher简介操作流退出页边界Memory Map控制寄存器L2 Prefetcher 初始化L2 prefetcher是U64内核新增的功能&#xff0c;U54内核没有这个功能。打开L2 prefetcher功能后&#xff0c;当访问大片内存&#xff0c;同时dcache中没有缓存时&#xff0c;访问内存的速率可以提…

用R语言和python进行社交网络中的社区检测

在这篇文章中&#xff0c;我用R语言和python检测社交网络中的社区。最近我们被客户要求撰写关于社区检测的研究报告&#xff0c;包括一些图形和统计输出。 相关视频&#xff1a;复杂网络分析CNA简介与R语言对婚礼数据聚类&#xff08;社区检测&#xff09;和可视化|数据分享 复…

(一)LTspice简介

文章目录前言一、举例1.1、RC滤波1.2、仿真结果二、软件安装总结前言 LTspice是一款高性能SPICE仿真器软件&#xff0c;包括原理图捕获图形界面。可探测原理图以产生仿真结果&#xff0c;通过LTspice内置波形查看器轻松探索。与其他SPICE解决方案相比&#xff0c;LTspice的增强…

mysql之SQL练习

常见面试题 学生表&#xff1a;student(学号,学生姓名,出生年月,性别) 成绩表&#xff1a;score(学号,课程号,成绩) 课程表&#xff1a;course(课程号,课程名称,教师号) 教师表&#xff1a;teacher(教师号,教师姓名) 1查询学生总成绩排名 SELECTstu_no,sum(score_prize) AS to…

安装Hadoop下hive的问题

ji问题的主要来源&#xff0c;由于收到安装文档后替换了一下&#xff0c;出现的问题 一&#xff0c;配置完成后&#xff0c;系统变量需要重启虚拟机&#xff0c; bash 变量需要刷新 #系统环境变量需要重启&#xff0c;bash变量只要source或切换就可以 source .bash_profile 我…