mongodb基础语法
Mongodb与关系型数据库最大的区别就是无约束, 既无字段(外键等)约束, 也没有数据类型约束, 以json存储
安装
启动Mongodb(默认在c盘找 data/db/文件夹)
服务端:
mongod --dbpath "指定数据库目录"
默认端口 27017
客户端:
mongo
常用命令:
show dbs
查看所有存在磁盘上的数据库
show tables
查看当前数据库存在磁盘上的表(collections)
use db
创建(不存在这个名字) 或者 切换数据库
db
当前数据库
db.user(表名)
创建表
增
db.user.insertOne({"name": "Amber"})
db.user.insertMany([{"name": "May"}, {"name": "Ryan"])
删
db.user.deleteOne({"name": "Amber"})
db.user.deleteMany([{"name": "May"}, {"name": "Ryan"])
改
updata 需要结束一下修改器
({"条件"},{"关键字(修改器)":{"修改内容"}})
$set 修改, 没有则添加一个字段
db.user.updataOne({'name': 'Ryan'}, {$set: {'age': 18}})
$unset 删除Field
db.user.updataOne({'name': 'Ryan'}, {$unset: {'age': 1}})
$inc 将查询到的某个结果,加上一个某个值
db.user.updateOne({'name': 'Ryan'}, {$inc: {'age': -10}})
array 修改器
$push 在array(list)尾端添加一个新元素
db.user.updateOne({'name': 'Ryan'}, {$push: {'hobby': '喝酒'}})
$pull 删除某一个元素
db.user.updateOne({'name': 'Ryan'}, {$pull: {'hobby': '做梦'}})
$pop 删除 1是倒数第一个, -1 是正数第一个
db.user.updateOne({'name': 'Ryan'}, {$pull: {'hobby': 1}})
$pushAll
db.user.updateOne({'name': 'Ryan'}, {$pushAll: {'hobby': ['爬山', , '游泳']}})
$ 代指符 $存储符合条件的元素下标(索引)
Array中的Object
"hobby" : [
"喝酒",
{
"name" : "ball",
"price" : 100
},
"爬山",
"游泳"
如果要修改 ball 的价格 200
db.user.updateOne({'hobby.name': 'ball'}, {$set: {'hobby.$.price': 200}})
Object中的Array
{
"info" : {
"id" : 1,
"name" : "Ryan",
"age" : 73,
"hobby" : [
"喝酒",
"爬山"
]
}
}
把喝酒改成游泳
db.user.updataOne({'info.hobby': '喝酒'}, {$set: {'info.hobby.$': '游泳'}})
查
db.user.find({条件})
且
db.user.find({{"id":2,"age":18}})
或
db.user.find({$or: [{'age': {$gt: 18}}, {'name': 'May'}]})
in
db.user.find({'age': {$in: [10, 20, 30]}})
sort, skip, limit:
skip(5) 跳过五条数据
limit(5) 只显示五条数据
sort({age:1}) 升序
sort({age:-1}) 降序
如果三个关键字同时出现,优先级如下
1.sort 2.skip 3.limit
db.user.find().sort({'field': 1 or -1}).skip(n).limit(n)
pymongo
注意:
'_id': ObjectId('5c3eddb16c347e190d0510cc' 是ObjectId类的对象
如果要序列化,也先str(_id),强转字符串在序列化
mongodb基础语法的更多相关文章
- mongodb 基础语法
参考原文:菜鸟教程 目录 一.数据库二.文档三.索引四.聚合 一.数据库 show dbs -- 查看所有数据库 use DATABASE_NAME -- 如果数据库不存在,则创建数据库,否则切换到指 ...
- 2019-10-30:渗透测试,基础学习,mssql堆叠内联注入,mongodb基础语法
使用xp_cmdshell需要堆叠注入,http://192.168.190.148/less-1.asp?id=1';EXEC sp_configure 'show advanced options ...
- MongoDB基础知识 02
MongoDB基础知识 02 6 数据类型 6.1 null : 表示空值或者不存在的字段 {"x":null} 6.2 布尔型 : 布尔类型只有两个值true和false {&q ...
- MongoDB基础知识 01
MongoDB基础知识 1. 文档 文档是MongoDB中的数据的基本单元,类似于关系型数据库管理系统的行. 文档是键值对的一个有序集.通常包含一个或者多个键值对. 例如: {”greeting& ...
- MongoDB 基础(2019年开篇)
MongoDB基础知识: 1.什么是MongoDB NoSQL(NoSQL=Not Only SQL),意即"不仅仅是SQL". MongoDB是一个介于关系数据库和非关系数据库之 ...
- Hive学习笔记:基础语法
Hive基础语法 1.创建表 – 用户表 CREATE [EXTERNAL外部表] TABLE [IF NOT EXISTS 是否存在] HUserInfo ( userid int comment ...
- MongoDB基础教程[菜鸟教程整理]
MongoDB基础教程 ======================================================================================== ...
- 分布式文档存储数据库之MongoDB基础入门
一.MongoDB简介 MongoDB是用c++语言开发的一款易扩展,易伸缩,高性能,开源的,schema free 的基于文档的nosql数据库:所谓nosql是指不仅仅是sql的意思,它拥有部分s ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
随机推荐
- linux系统抓包命令
IP地址抓包:tcpdump -i any host 1.1.1.2 -n 端口抓包: tcpdump -i any port 6789 -n wireshak工具抓包:tcp.port == 678 ...
- Mybatis输入输出映射
一.输入映射 1.传递简单类型 <select id="findUserById" parameterType="int" resultType=&quo ...
- Hadoop学习笔记(1):WordCount程序的实现与总结
开篇语: 这几天开始学习Hadoop,花费了整整一天终于把伪分布式给搭好了,激动之情无法言表······ 搭好环境之后,按着书本的代码,实现了这个被誉为Hadoop中的HelloWorld的程序--W ...
- 【MD5加密】MD5加密编码的坑
MD5 MD5即Message-Digest Algorithm (信息-摘要算法5),用于确保信息传输完整一致. 是计算机广泛使用的杂凑算法之一(又译摘要算法.哈希算法),主流编程语言普遍已有MD5 ...
- 【CSS系列】height:100%设置div的高度
一.div设置百分百高度实现描述 在html布局中body内第一个div盒子对象设置100%高度height样式,是无法成功显示100%高度的.这个是因为body高度默认值为自适应的,所以及时设置bo ...
- document.visibilityState 监听浏览器最小化
document.hidden:表示页面是否隐藏的布尔值.页面隐藏包括 页面在后台标签页中 或者 浏览器最小化 (注意,页面被其他软件遮盖并不算隐藏,比如打开的 sublime 遮住了浏览器). do ...
- [原]git的使用(三)---管理修改、
上接git的使用(二) 7.管理修改 [要理解的概念]为Git跟踪并管理的是修改,而非文件 什么是修改?比如你新增了一行,这就是一个修改,删除了一行,也是一个修改,更改了某些字符,也是一个修改,删了一 ...
- select默认下拉箭头改变、option样式清除
谷歌.火狐.ie下 select 的默认下拉箭头图标差别还是比较大,一般我们都会清除默认样式,重新设计箭头图标: /* --ie清除--*/ select::-ms-expand{ display: ...
- 生产环境的gitlab大版本升级思路(从7.x升级到8.x)
之前在生产环境部署的gitlab是7.x版本的,提供给公司内部的员工来使用,大概有350个用户左右,gitlab从8.x版本之后内置了CI和CD的集成,所以就考虑到升级版本的问题 通过参考和总结git ...
- matlab中 数据保留有效位数
可以使用round函数 ,这函数原本功能是四舍五入 比如: >> A = 0.0326465;>> B = round(A*1000)/1000 B = 0.0330