mongodb数据库的改操作
原来字段:
{
"_id" : ObjectId("5df0a28e406405edeac5001f"),
"username" : "修改这一条,别的还存在不",
"password" : "xxxxxxxxxxx",
"open_id" : "",
"union_id" : "",
"telphone" : "",
"nickname" : "洛城陛下",
"farm_id" : [
"牧场id1",
"牧场id2"
],
"is_active" : "",
"is_detele" : "",
"email" : "xxxxxx",
"photo" : "https://www.123.png",
"gov_addr" : "xxxxxxx",
"auth_code" : "",
"register_time" : "2019-12-10",
"update_time" : "2019-12-10"
}
需求一:只更新 password,telephone等字段----更新一般非嵌套字段
方法:局部更新,使用 {$set:{"username":"要修改的值"}}
python代码操作
from pymongo import MongoClient
# 这里需要说明,用_id当做查询条件,必须导入这个类,要不然报错
from bson.objectid import ObjectId client = MongoClient(host="127.0.0.1",port=27017)
db = client["userinfo"]["user"] ret = db.update({"_id":ObjectId("5df0a28e406405edeac5001f")},{"$set":{"username":"python修改用户名"}}) print(ret) # 结果
{'n': 1, 'nModified': 1, 'ok': 1.0, 'updatedExisting': True} # 要更新的值,和原来的值一样,则会返回 {'n': 1, 'nModified': 0, 'ok': 1.0, 'updatedExisting': True}
修改后的字段:
{
"_id" : ObjectId("5df0a28e406405edeac5001f"),
"username" : "python修改用户名",
"password" : "xxxxxxxxxxx",
"open_id" : "",
"union_id" : "",
"telphone" : "",
"nickname" : "洛城陛下",
"farm_id" : [
"牧场id1",
"牧场id2"
],
"is_active" : "",
"is_detele" : "",
"email" : "xxxxx",
"photo" : "https://www.123.png",
"gov_addr" : "xxxxxxx",
"auth_code" : "",
"register_time" : "2019-12-10",
"update_time" : "2019-12-10"
}
需求二:更新farm_id里面的第一个元素的值为 这是数组第一个元素更新后的值
方法:局部更新:数组里面的指定的元素(而非对象)的值 使用下标进行修改
数组里面放的是元素
{"name":"zhang",
"friends":["张三","李四","王五"]}
数组里面放的是字典对象
{"name":"zhang",
"friends":[{"a":1,"b":2},{"c":3,"d":4}]}
更新前的字段:就是修改后的字段
python代码操作
from pymongo import MongoClient
from bson.objectid import ObjectId
client = MongoClient(host="127.0.0.1",port=27017)
db = client["userinfo"]["user"] ret = db.update({"_id":ObjectId("5df0a28e406405edeac5001f")},{"$set":{"farm_id.1":"python修改后的值"}}) print(ret) # 结果
{'n': 1, 'nModified': 1, 'ok': 1.0, 'updatedExisting': True}
更新后的值
{
"_id" : ObjectId("5df0a28e406405edeac5001f"),
"username" : "python修改用户名",
"password" : "xxxxxxxxxxx",
"open_id" : "",
"union_id" : "",
"telphone" : "",
"nickname" : "洛城陛下",
"farm_id" : [
"牧场id1",
"python修改后的值"
],
"is_active" : "",
"is_detele" : "",
"email" : "xxxxxx",
"photo" : "https://www.123.png",
"gov_addr" : "xxxxxxx",
"auth_code" : "",
"register_time" : "2019-12-10",
"update_time" : "2019-12-10"
}
假如数组里面放的是字典对象,怎么修改对象的key的值?
新建数据格式为:
{
"_id" : ObjectId("5df0b4bb406405edeac502a3"),
"username" : "python修改用户名",
"password" : "xxxxxxxxxxx",
"farm_id" : [
{
"a" : 1
},
{
"a" : 2
}
]
}
需求:修改第一个数组里面的a的值为:python修改后的值
python代码操作
from pymongo import MongoClient
from bson.objectid import ObjectId
client = MongoClient(host="127.0.0.1",port=27017)
db = client["userinfo"]["user"] ret = db.update({"_id":ObjectId("5df0b4bb406405edeac502a3")},{"$set":{"farm_id.0.a":"python修改后的值"}}) print(ret) # 结果
{'n': 1, 'nModified': 1, 'ok': 1.0, 'updatedExisting': True}
修改后的数据格式:
{
"_id" : ObjectId("5df0b4bb406405edeac502a3"),
"username" : "python修改用户名",
"password" : "xxxxxxxxxxx",
"farm_id" : [
{
"a" : "python修改后的值"
},
{
"a" : 2
}
]
}
但是有一个问题,假如不知道下标,但是要精准的修改数组中,指定对象的键值对的值,可以给每个对象,增加一个唯一id字段,过滤条件换成唯一id字段,而不是_id
新建数据结构
{
"_id" : ObjectId("5df0b4bb406405edeac502a3"),
"username" : "python修改用户名",
"password" : "xxxxxxxxxxx",
"farm_id" : [
{
"a" : "python修改后的值",
"id" : ""
},
{
"a" : 2,
"id" : ""
}
]
}
python操作代码
from pymongo import MongoClient
from bson.objectid import ObjectId
client = MongoClient(host="127.0.0.1",port=27017)
db = client["userinfo"]["user"]
# 查询条件为 farm_id.id是为了精准定位
ret = db.update({"farm_id.id":""},{"$set":{"farm_id.$.a":"python通过唯一字段,精准定位"}})
print(ret) # 结果
{'n': 1, 'nModified': 1, 'ok': 1.0, 'updatedExisting': True}
修改后的字段
{
"_id" : ObjectId("5df0b4bb406405edeac502a3"),
"username" : "python修改用户名",
"password" : "xxxxxxxxxxx",
"farm_id" : [
{
"a" : "python通过唯一字段,精准定位",
"id" : ""
},
{
"a" : 2,
"id" : ""
}
]
}
updata的参数 upsert = True 或 False
collection_name = "demo"
数据为: 数据只有一条,查找farm_id=2,修改 nick_name="大碗宽面",upsert=True
{
"farm_id":"",
"breed_detail":[
{
"user_id":"",
"nick_name":"吴亦凡"
}
]
}
python代码
# TODO
mongodb数据库的改操作的更多相关文章
- 第一篇:一天学会MongoDB数据库之Python操作
本文仅仅学习使用,转自:https://www.cnblogs.com/suoning/p/6759367.html#3682005 里面新增了如果用用Python代码进行增删改查 什么是MongoD ...
- mysql数据库和mongodb数据库的相关操作以及两个数据库的区别
在docs命令中执行数据操作 MySQL数据库 先启动MySQL服务器 net start mysql 进入MySQL服务器MySQL -uroot -p(这里写你的数据库密码) (-P是从哪个端口 ...
- Python连接MongoDB数据库并执行操作
原文:https://blog.51cto.com/1767340368/2092813 环境设置: [root@mongodb ~]# cat /etc/redhat-release CentOS ...
- MongoDB数据库文档操作
前面的话 本文将详细介绍MongoDB数据库关于文档的增删改查 数据类型 在介绍文档操作之前,首先要了解MongoDB的数据类型 MongoDB支持许多数据类型,包括 1.字符串 - 这是用于存储数据 ...
- Mongodb数据库(linux)——基础操作
简介 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统.它是非关系型数据库,但其结构与MySQL又很相似,mysql中的表格,在这里被称为集合,mysql表格内的数据是一 ...
- ThingkPHP对数据库进行改操作
public function test_check(){ $Experiment = M("Experiment");//实例化Experiment对象.这个对象是跟数据库的表对 ...
- java对mongodb数据库的简单操作
准备工作: 下载好mongodriver.jar包(https://oss.sonatype.org/content/repositories/releases/org/mongodb/mongodb ...
- mongodb数据库集合操作
1:更新update update() 方法用于更新已存在的文档.语法格式如下: db.collection.update( <query>, <update>, { upse ...
- NodeJS操作MongoDB数据库
一.node.js对于mongodb的基本操作 1.数据库的开机 首先我们要先对数据库进行开机的操作,建立一个文件夹用于存放数据库文档.如D:\mongo,接下去在cmd当中键入命令-> mon ...
随机推荐
- apache通过rewrite限制某个目录
1.<IfModule mod_rewrite.c> RewriteEngine on RewriteCond %{HTTP_URI} ^.*/tmp/* [NC] RewriteRule ...
- flex label如何通过AS3实现颜色设置
如果你想修改label的颜色,你可以在控件上面直接设置color属性,但是有这样一个情况,有些label的颜色是动态设置的,没办法一开始初始化的时候设置 这个时候就需要在AS当中动态的设置,直接.se ...
- 【图形学手记】Inverse Transform Sampling 逆转换抽样
需求: 我们通过调查,得知大多数人在20岁左右初恋,以20岁为基准,以随机变量X表示早于或晚于该时间的年数,为了简单,假设X值域为[-5,5],并且PDF(X)是一个正态分布函数(当然可以为任意分布, ...
- IOS CocoaPods详细使用方法
自从有了CocoaPods以后,这些繁杂的工作就不再需要我们亲力亲为了,只需要我们做好少量的配置工作,CocoaPods会为我们做好一切 一.什么是CocoaPods 1.为什么需要CocoaPo ...
- ENVI-IDL的MATH_DOIT和CF_DOIT函数(对FID和POS参数的讨论)
MATH_DOIT相当于ENVI的band math,可以完成各种波段运算.参数比较简单,EXP为运算公式的字符串,其他参数均为常见参数. CF_DOIT可以将已有的文件保存为ENVI格式文件,相当于 ...
- Shell编程、part4
本节内容 1. shell函数 2. shell正则表达式 shell函数 shell中允许将一组命令集合或语句形成一段可用代码,这些代码块称为shell函数.给这段代码起个名字称为函数名,后续可以直 ...
- Centos7单机安装Tableau2018.2
cd先将服务器防火墙80级8850端口打开 临时关闭SELinux/防火墙 setenforce 0 iptables -F 重点 重点 不能用root用户安装 不能用root用户安装 第一步先创建一 ...
- 【Linux 网络编程】滑动窗口协议
<1>通知接受窗口(rwnd): 预防应用程序发送的数据超过对方的缓冲区.接收方使用的流量控制<2>拥塞窗口(cwnd): 预防应用程序发送的数据超过网络所承受的能力.发送方使 ...
- spring boot-17.RabbitMQ
1.JMS&AMQP JMS(Java MessageService)实际上是指JMS API.JMS是由Sun公司早期提出的消息标准,旨在为java应用提供统一的消息操作,包括create. ...
- P1057传球游戏
这是一道动态规划的水题,难度为提高-. 题意为:n个人围成一个环传球,每一次都可以往左或右传,传m次,问有几种最后传到小明手里的方案数.然后因为一个状态有两个变量,所以我们用dp[][]来存储[传球次 ...