MongoDB初探-基本语句和数据结构
MySQL:
1 金老板 18 15512351234
2 小哪吒 20 15312341234
3 Alex 73 15512341234
MongoDB:
{
{
id : 1,
name:金老板,
age : 18,
phone:15512351234
},
{
ids : 1,
names:金老板,
ages : 18,
phones:15512351234
}
}
1.MongoDB的启动 CMD :
mongod --dbpath="D:/data/db/"
客户端 : mongo
2.指令
- show databases - 显示数据库(在磁盘中存储的数据库)
- db - 显示当前使用的数据库
- use db_name - 切换使用中的数据库,如果数据库不存在,在内存中创建一个数据库空间大小是0
- db.user - 在当前数据库的内存中创建一个数据表空间 大小是0
- show tables - 显示当前数据库中的数据表 (存放在磁盘中的)
在MongoDB - 使用了不存在的对象,即创建该对象
3.MongoDB的增删改查:
增加数据:
单个信息增加
不推荐写法
db.user_info.insert({
"name":"alexdsb",
"age":73
})
多条增加:
不推荐写法
db.user_info.insert([{"name":1},{"name":3},{"name":2}])
官方推荐写法:
db.user_info.insertOne({})
db.user_info.insertMany([{},{}])
查找数据:
db.user_info.find({})
db.user_info.find({"age":73})
db.user_info.findOne({"age":73})
修改数据:
官方不推荐 // 修改器:$set
db.user_info.update({"age":73}, {$set:{"name":"JWB"}})
官方推荐
db.user_info.updateOne({"age":73}, {$set:{"name":"JWB"}})
db.user_info.updateMany({"age":73}, {$set:{"name":"JWB"}})
删除数据:
官方不推荐
db.user_info.remove({name:111})
官方推荐
db.user_info.deleteOne({name:1})
db.user_info.deleteMany({name:1})
_id = ObjectID
关系型数据库中的 自增ID 以数据库为核心的自增
表为核心的自增ID
user - book
1 1
2 2
3 3
数据库为核心的自增ID ObjectID宇宙唯一的
user - book - auth
1 4 7
2 5 8
3 6 9
10 11 12
13 14 15
4.数据类型:
- ObjectID 自动创建的 一个字符串 Documents 自生成的 _id
- String 字符串类型 不需要限定长度的
- Boolean:布尔值,true 或者false
- Double:浮点数 (没有float类型,所有小数都是Double) !float是不存在的
- Integer:整型 数据类型
- Arrays:[] 数组类型 在python中就是个列表
- Object:{} 对象类型 在python中就是个字典 在其他语言中叫 Object
- Null == None
- 时间数据类型 - Timestamp - Date
5.MongoDB与关系型数据库概念的变差:
关系型数据库 | MongoDB |
---|---|
database | database |
table | Collections |
row | Documents |
Colunm数据列 | Field |
6.MongoDB修改器
$set
: 强制修改
{$set:{"name":1}} == (dict["key"] = value)$unset
: 删除Key 删除Field (del dict["key"])
db.school.updateOne({"school_name":"OldBoy"},{$unset:{"student_list":1}})$inc
引用增加
db.user_info.updateMany({},{$inc:{"age":1}})针对Array的操作
$push
- 在Array中增加一条数据db.school.updateOne({"class_name":"S16"},{$push: {student_list:{"name":"JSJ","age":25,"gender":"Null"}}})
$pushAll
在Array中添加多条数据:db.school.updateOne({"type":"list"},{$pushAll:{"num_list":["a","b","c"]}})
$pull
=>[].remove
- 在Array中删除符合条件的元素db.school.updateOne({"type":"list"},{$pull:{"num_list":2}}) db.school.updateOne({"school_name":"OldBoy"},{$pull:{"student_list":{"name":"JSJ"}}})
$pullAll
- 在Array中删除所有符合条件的元素db.school.updateOne({"type":"list"},{$pullAll:{"num_list":[1,2,3]}})
$pop
=>[].pop()
- 删除Array中的第一条或最后一条db.school.updateOne({"student_list.name":"JSJ"},{$pop: {"student_list":-1}}) -1:第一个
db.school.updateOne({"student_list.name":"JSJ"},{$pop: {"student_list":1}}) 1: 最后一个
7.$ 字符
存储符合条件Array中元素的下标索引
8.针对Object的更新操作
db.school.updateOne({"school_name":"OldBoy"},{$set:{"student.age":84}})
db.school.updateOne({"school_name":"OldBoy"},{$inc:{"student.age":1}})
9.$数学比较符
$lt
<
$gt
>
$lte
<=
$gte
>=
$eq
== db.school.find({"age":{"$eq":3}})
$ne
!= db.school.find({"age":{"$ne":3}})
10.条件分隔:
and :
db.school.find({"class_name":"S16","school_name":"OldBoy"})
db.school.find({$and: [{"school_name":"OldBoy"},{"class_name":"S16"}]})
or :
db.school.find({$or:[{"school_name":"OldBoy"},{"class_name":"S16"}]}) 不同字段的or
in :
db.school.find({"school_name":{"$in":["OldBoy","OldBoySZ"]}}) 相同字段的or
all :
db.school.find({"userlist":{$all:[4,3,2]}}) 子集查询
11.limit sort skip
// limit 选取
db.school.find({}).limit(5)
// skip 跳过
db.school.find({}).skip(5)
// sort 排序
db.school.find({}).sort({ age:-1 })
db.school.find({}).sort({ age:1 })
// 跳过 选取
db.school.find({}).skip(5).limit(5)
db.school.find({}).limit(5).skip(5)
// 排序 跳过 选取
db.school.find({}).limit(5).skip(5).sort({ age:-1 })
// 分页 每页3条
// 第一页
db.school.find({}).limit(3).skip(0).sort({ _id:1 }) // (page - 1) * 3
// 第二页
db.school.find({}).limit(3).skip(3).sort({ _id:1 }) // (page - 1) * 3
// 第三页
db.school.find({}).limit(3).skip(6).sort({ _id:1 }) // (page - 1) * 3
12.pymongo - 使用python操作MongoDB
MongoDB初探-基本语句和数据结构的更多相关文章
- mongodb常用操作语句
mongodb常用操作语句 A:创建数据表 db.createCollection(name, {capped: <Boolean>, autoIndexId: <Boolean&g ...
- MongoDB对应SQL语句
-------------------MongoDB对应SQL语句------------------- 1.Create and Alter 1. sql: crea ...
- mongodb 跟踪SQL语句及慢查询收集
有个需求:跟踪mongodb的SQL语句及慢查询收集 第一步:通过mongodb自带函数可以查看在一段时间内DML语句的运行次数. 在bin目录下面运行 ./mongostat -port 端口号 ...
- Mongodb 与sql 语句对照
此处用mysql中的sql语句做例子,C# 驱动用的是samus,也就是上文中介绍的第一种. 引入项目MongoDB.dll //创建Mongo连接 var mongo = new Mongo(&qu ...
- mongodb的更新语句
MongoDB 使用 update() 和 save() 方法来更新集合中的文档: update()方法: update() 方法用于更新已存在的文档.语法格式如下: db.collection.up ...
- mongodb的查询语句学习摘要
看了些资料,对应只需要知道怎么查询和使用mongodb的我来说,这些足够啦. 左边是mongodb查询语句,右边是sql语句.对照着用,挺方便. db.users.find() select * fr ...
- MongoDB初探系列之二:认识MongoDB提供的一些经常使用工具
在初探一中,我们已经能够顺利的将MongoDB在我们自己的机器上跑起来了. 可是在其bin文件夹以下另一些我们不熟知的工具.接下来,将介绍一下各个小工具的用途以及初探一中MongoDB在data文件夹 ...
- 深入理解mongodb查询条件语句
阅读目录 1. 理解:"$lt"."$lte"."$gt" 和 "$gte" 2. 理解 '$ne' 3. 理解 &qu ...
- MongoDB简单查询语句<平时使用语录,持续更新>
MongoDB查询语句 --查询近三个月的客户使用量 aggregate:使用聚合 match:过滤 group分组 -- mysql中select org_code as 近三个月使用商户 ...
随机推荐
- docker file 示例
报错 Cannot connect to the Docker daemon. Is the docker daemon running on this host? 这个错误只要输入docker -d ...
- sha256加密
sha256: 1.使用npm安装 :npm install js-sha256 2.然后在组件中methods定义方法,在调用 // sha256加密密码 setSha(){ let sha256 ...
- mybatis 直接执行sql 【我】
Connection conn = getConnection();// Connection conn = this.ss.getConnection(); 返回Connect ...
- JAVA设计模式初探之适配器模式
http://blog.csdn.net/jason0539/article/details/22468457 1. 概述 将一个类的接口转换成客户希望的另外一个接口.Adapter模式使得原本由于接 ...
- java 学习:在java中启动其他应用,由jenkins想到的
在jenkins的实践中遇到了一个问题: 我的项目依赖其他第三方应用的地方比较多,而且会占用多个端口,如何处理端口和启动/关闭第三方应用成了难题. 初级解决方案:在服务端上面写一堆bat文件,,,,_ ...
- 随机数Random
掷骰子10次,统计1.2出现的次数 public static void Main(string[] args) { ,a2=; Random random=new Random();//创建随机数对 ...
- STM32F4 ------ RTC
如果只执行 HAL_RTC_GetTime(),读取完后时间不再跑 HAL_RTC_GetTime() 和 HAL_RTC_GetDate()
- 微信小程序:多张图片上传
最近在写小程序的相册,需要多张图片的上传.因为小程序不支持数组的多张图片同时上传,然后根据自己的需求+借鉴网上各位大神的案例,总算搞定.分享下,不足之处,多多指教哦 页面wxml: <form ...
- maven编译或者打包web项目显示“软件包 javax.servlet.http 不存在"
2.解决办法: 这是由于缺少servlet-api.jar包,其实tomcat下有,但是在java build path把他加载过来,还是报这个错误,所以我们直接在pom.xml里面加入这个jar包即 ...
- 剑指Offer_编程题_18
题目描述 操作给定的二叉树,将其变换为源二叉树的镜像. 输入描述: 二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ ...