mongdb基本使用
mongodb创建用户,设置密码
参考:https://www.jianshu.com/p/237a0c5ad9fa
MongoDB内置的数据库角色有:
1. 数据库用户角色:read、readWrite;
2. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
4. 备份恢复角色:backup、restore;
5. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
6. 超级用户角色:root
7. 内部角色:__system
引用自: https://www.cnblogs.com/qk2014/p/9253506.html
mongodb基本使用
use DATABASE_NAME
如果数据库不存在,则创建数据库,否则切换到数据库。
show dbs
显示所有的数据库
db.dropDatebase()
删除当前所使用的数据库
db.createCollection(name,options)
创建名为name的集合
show collections
显示所有的集合
db.collection.drop()
删除名为collection的集合
db.COLLECTION_NAME.insert(document)
向集合COLLECTION_NAME中插入document
db.COLLECTION_NAME.insertOne(document)
向集合COLLECTION_NAME中插入一条document
db.COLLECTION_NAME.insertMany([document1,document2...])
向集合COLLECTION_NAME中插入多条document
db.COLLECTION_NAME.update(<filter>,<update>,{...参数})
更新COLLECTION_NAME中的记录
filter:过滤条件,update:需要更新的数据
参数:
upsert:可选,如果不存在update的记录,是否插入objNew,true为插入,false为不插入
multi:可选,只更新第一条记录,如果这个参数为true,则全部更新,为false则只更新一条数据,mongodb默认为false
writeConcern:可选,抛出异常的级别
db.COLLECTION_NAME.delateOne(<filter>)
删除COLLECTION_NAME集合中的一条记录
filter:过滤条件
db.COLLECTION_NAME.delateMany(<filter>)
删除COLLECTION_NAME集合中的多条记录
filter:过滤条件
db.COLLECTION_NAME.findOne(<filter>)
查询COLLECTION_NAME集合中的一条记录
filter:过滤条件
db.COLLECTION_NAME.findMany(<filter>)
查询COLLECTION_NAME集合中的多条记录
filter:过滤条件
db.user.find({"name":"/帅/"})
在user集合中查找name中包含"帅"的记录
db.user.find({"name":"/^帅/"})
在user集合中查找name中开头为"帅"的记录
db.user.find({"name":"/帅$/"})
在user集合中查找name中结尾为"帅"的记录
条件语句查询
| 操作 | 格式 | 案例 |
|---|---|---|
| 等于 | {key: value} | db.user.find({"name": "yven"}) |
| 小于 | {key: {$lt: value}} | db.user.find({"age": {$lt: 20}}) |
| 小于或等于 | {key: {$lte: value}} | db.user.find({"age": {$lte: 20}}) |
| 大于 | {key: {$gt: value}} | db.user.find({"age": {$gt: 20}}) |
| 大于或等于 | {key: {$gte: value}} | db.user.find({"age": {$gte: 20}}) |
| 不等于 | {key: {$ne: value}} | db.user.find({"age": {$ne:20}}) |
AND和OR
在find方法中传入多个键,每个键以逗号隔开,就是AND条件,如:
db.user.find({"name":"yven","age",18})
在user集合中查找name为yven而且age为18的记录
OR条件使用关键字$or,如:
db.user.find({"$or":[{"name":"yven"},{"name":"lyf"}]})
在user集合中查找name为yven或者name为lyf的记录
$type实例
$type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果
MongoDB中可以使用的类型参考如下:
https://www.runoob.com/mongodb/mongodb-operators-type.html
使用$type实例
db.user.find({"name":{$type:2}})
$type 为2对应的数据类型为string,所以这条语句就是在user集合中查询name为string类型的记录
也可以写为:db.user.find({"name":{$type:"string"}})
pymongodb基本使用
from pymongo import MongoClient
mongodb_add = "mongodb://user:pwd@host:port"
client = MongoClient(mongodb_add)
# 获取数据库
db = client["datebase_name"]
# 获取集合
collection = db["collection_name"]
# 操作就完事
yven = collection.find_one({"name":"yven"})
# 模糊查询,查看name中包含y的记录条数
count = collection.find({"name": {'$regex': ".*y.*"}}).count()
mongdb基本使用的更多相关文章
- solr+mongo-connector+mongdb+tomcat集成
话题:solr安装 一.下载solr 本例采用4.10.3版本. Solr所有版本下载地址:http://archive.apache.org/dist/lucene/solr/ 下载完成后,解压的目 ...
- [MongDB] 主从架构--官方极力不推荐
一.缘由: 看着数据库大家庭都有主从模式,想着Mongodb应该也不会落下.但从官网看来,先是早先舍弃了Master-Master模式,现在又在不推荐 Master-Slave模式,这是要标新立异呀. ...
- MongDB/C# 杂项
1.MongDB的时间类型字段输出时为UTC的解决方法:保存到数据库中的数据还是按UTC存的,读出来的就按标识值读 [BsonDateTimeOptions(Kind = DateTimeKind.L ...
- HBase与MongDB等NoSQL数据库对照
HBase概念学习(十)HBase与MongDB等NoSQL数据库对照 转载请注明出处: jiq•钦's technical Blog - 季义钦 一.开篇 淘宝之前使用的存储层架构一直是MySQL数 ...
- go语言mongdb管道使用
原始json: { "listsn": "", "code": "fwq_add", "detail" ...
- HBase概念学习(十)HBase与MongDB等NoSQL数据库对照
转载请注明出处: jiq•钦's technical Blog - 季义钦 一.开篇 淘宝之前使用的存储层架构一直是MySQL数据库,配合以MongDB,Tair等存储. MySQL因为开源,而且生态 ...
- mongdb创建自增主键(primary key)的相关讨论 - Jason.Zhi
根据mongodb官方文档介绍,如果在插入(insert)操作时,没有指定主键id,那么它会自动给插入行自动附上一个主键id.看起来不错,但是详细看看,就会发现这个id值有点复杂. 如下图: mong ...
- mongdb Java demo
接触MONGDB,感觉用起来还挺好.今天做了一个小demo. 一.启动mongdb的服务
- mongDB 的使用
首先是启动 mongdb的service ,不启用的话,使用mong shell 连接的现象是: 启动服务端,指定默认的存储的位置即可: mongod -- dbpath F:/store #数 ...
- springMVC+ mongdb + redis +Jedis 环境搭建
环境信息: JDK1.7 : Eclipse 4.4.1 ; mongdb + mongVUE:mongDB的安装 redis的下载和安装:window下安装redis maven3.0.5 新建ma ...
随机推荐
- BZOJ 4919: [Lydsy1706月赛]大根堆 set启发式合并
这个和 bzoj 5469 几乎是同一道题,但是这里给出另一种做法. 你发现你要求的是一个树上 LIS,而序列上的 LIS 有一个特别神奇的 $O(n\log n) $ 做法. 就是维护一个单调递增的 ...
- Redis的移库操作
1.Redis默认有16个数据库,一般情况下使用0库: 2.移库操作: 将mysets移到一号库: 通过Redis查看器查看: 通过命令查看:
- mysql linux上安装使用
安装启动 安装之前可以看下系统中有没有已经安装. 查看所有软件:dpkg -l 1.查看mysql安装的版本 mysql --version 2.mysql状态 service mysql statu ...
- PowerDesigner 创建表的时候 没有自增长Id的设置项
今天早上同事创建表的时候,在那个界面没有自增长Id的选项,当时我也纳闷,软件肯定都是一样的,设置的步骤都一样(有些配置好的 我就没改过 然后就忘了还改过些什么步骤了),结果还是没有那个选项 百度了一下 ...
- codevs 2780 ZZWYYQWZHZ
2780 ZZWYYQWZHZ 时间限制: 1 s 空间限制: 32000 KB 题目等级: 青铜 Bronze 题目描述 Description 可爱的小管在玩吹泡泡.忽然,他想到 ...
- uni-app input text-indent失效解决
有两种方法去解决 第一种 input { padding-left: 10upt } 第二种 input { display: block }
- Shell脚本实现对文件编辑
常见Linux文件的编辑命令 vi/vim,有时候我们想写一个脚本实现对文件编辑,这个时候,可能就不够用了,下面介绍一些办法 1.echo命令 Shell的echo命令常用于字符串的输出 例如: [r ...
- linux学习(5):linux 性能瓶颈排查
作为开发人员,肯定遇到过以下场景,应用突然卡住了,或者异常退出,cpu占用过高等各种异常情况,一般遇到这些异常情况,该如何去查找具体原因呢? linux和jdk提供了一些命令和工具来查看内存.cpu. ...
- Python 开发版本指导与资源
Python 文档:https://docs.python.org/3/ 下载 下载这些文件 文档版本 Python 3.9(开发中) Python 3.8(稳定) Python 3.7(稳定) Py ...
- linux,卸载文件系统的时候,报busy情况的解决记录
背景描述: 前几天由于文件系统io异常的问题,要对文件系统的属性进行修改,修改该参数需要将磁盘umount,在umount的过程中遇到问题,在此记录下. 处理过程: 1.执行umount进行卸载磁盘, ...