MongoDB 插入时间与更新时间(create_time/update_time)
前言
- MongoDB 在数据库层面不能像 MySQL 一样设置自动创建 create_time/update_time,自动更新 update_time
- 可以自己封装函数在应用程序中实现类似效果
- 推荐学习唐建法《MongoDB 高手课》
本文测试环境
# 服务端 Ubuntu 18.04 LTS MongoDB 4.2.5 # 客户端 Windows 10 Python 3.8.2 pymongo 3.10.1
实例
# 类似 MySQL 以下语句,并更新时间
INSERT INTO ... ON DUPLICATE KEY UPDATE ...
# 第一次执行时,生成 create_time 和 update_time
# 第二次执行时,更新 update_time
Mongo Shell
方式一
db.student.updateOne( { sno: 1 }, { $setOnInsert: { create_time: new Date() }, $set: { sname: "qbit", update_time: new Date() } }, { upsert: true } )
方式二(currentDate)
/* 约等于上面的语句。 通常下面的语句在新建 document 时, update_time 会比 create_time 晚一点。 因为 new Date() 是 js 函数,在客户端生成; currentDate 获取的是服务器时间 */ db.student.updateOne( { sno: 1 }, { $currentDate: { update_time: true }, $setOnInsert: { create_time: new Date() }, $set: { sname: "qbit" } }, { upsert: true } )
pymongo(reading-time)
Python 代码
#encoding: utf-8 #author: qbit #date: 2020-04-24 #summary: 封装 pymongo 函数,自动更新时间 import time from datetime import datetime, timedelta, timezone from pprint import pprint import pytz import pymongo from bson.codec_options import CodecOptions
def upsert_autotime(coll: pymongo.collection.Collection, filterDict: dict, updateDict: dict): r""" coll: MongoDB 集合 filterDict: 过滤条件,须是主键 updateDict: 更新字段内容 """ # 0 区 dt0 = datetime.utcnow() updateDict['update_time'] = dt0 updateDict = {'$set': updateDict} updateDict['$setOnInsert'] = { 'create_time': dt0 } return coll.update_one(filterDict, updateDict, upsert=True)
if __name__ == "__main__": username = 'qbit' password = 'xxx' host = '192.168.0.72' port = 27017 dbname = 'student' connStr = f'mongodb://{username}:{password}@{host}:{port}/{dbname}?authSource=admin' # 设置读取来时间的时区 options = CodecOptions(tz_aware=True, tzinfo=pytz.timezone('Asia/Shanghai')) db = pymongo.MongoClient(connStr).get_database(codec_options=options) coll = db.student coll.drop() filterDict = {"sno": 1} updateDict = {"sname": "qbit"} print('///////////////// 111 ///////////////////') upsert_autotime(coll, filterDict, updateDict) # 第 1 次执行 document = coll.find_one() document['create_time'] = document['create_time'].strftime('%Y-%m-%d %H:%M:%S') document['update_time'] = document['update_time'].strftime('%Y-%m-%d %H:%M:%S') pprint(document) print('///////////////// 222 ///////////////////') time.sleep(2) # 休眠 2s upsert_autotime(coll, filterDict, updateDict) # 第 2 次执行 document = coll.find_one() document['create_time'] = document['create_time'].strftime('%Y-%m-%d %H:%M:%S') document['update_time'] = document['update_time'].strftime('%Y-%m-%d %H:%M:%S') pprint(document)
运行结果
///////////////// 111 /////////////////// {'_id': ObjectId('5ea2acd4bb3447a6a5fe18fc'), 'create_time': '2020-04-24 09:09:39', 'sname': 'qbit', 'sno': 1, 'update_time': '2020-04-24 09:09:39'} ///////////////// 222 /////////////////// {'_id': ObjectId('5ea2acd4bb3447a6a5fe18fc'), 'create_time': '2020-04-24 09:09:39', 'sname': 'qbit', 'sno': 1, 'update_time': '2020-04-24 09:09:41'}
本文出自 qbit snap
qbit snap
开箱即用,拿走不谢。
262 声望
275 粉丝
推荐阅读
Windows 下多版本 Python 共享 Poetry(qbit)
前言技术栈 {代码...} Python 3.8 安装目录 {代码...} Python 3.11 安装目录 {代码...} 安装 poetry设置将以下路径加入 path 环境变量 {代码...} 复制文件 {代码...} 设置 pip 国内镜像源 {代码...} 升级 pip {代...
qbit阅读 235
万字详解,吃透 MongoDB!
MongoDB 是一个基于 分布式文件存储 的开源 NoSQL 数据库系统,由 C++ 编写的。MongoDB 提供了 面向文档 的存储方式,操作起来比较简单和容易,支持“无模式”的数据建模,可以存储比较复杂的数据类型,是一款非常...
JavaGuide赞 8阅读 1.8k
万字长文~vue+express+mysql带你彻底搞懂项目中的权限控制(附所有源码)
所谓的权限,其实指的就是:用户是否能看到,以及是否允许其对数据进行增删改查的操作,因为现在开发项目的主流方式是前后端分离,所以整个项目的权限是后端权限控制搭配前端权限控制共同实现的
水冗水孚赞 11阅读 1.6k
花了几个月时间把 MySQL 重新巩固了一遍,梳理了一篇几万字 “超硬核” 的保姆式学习教程!(持续更新中~)
MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。
民工哥赞 11阅读 1.2k
一次偶然机会发现的MySQL“负优化”
今天要讲的这件事和上述的两个sql有关,是数年前遇到的一个关于MySQL查询性能的问题。主要是最近刷到了一些关于MySQL查询性能的文章,大部分文章中讲到的都只是一些常见的索引失效场合,于是我回想起了当初被那个...
骑牛上青山赞 8阅读 2.3k评论 2
初学后端,如何做好表结构设计?
这篇文章介绍了设计数据库表结构应该考虑的4个方面,还有优雅设计的6个原则,举了一个例子分享了我的设计思路,为了提高性能我们也要从多方面考虑缓存问题。
王中阳Go赞 4阅读 894评论 2
2023最新MySQL高频面试题汇总
本文已经收录到Github仓库,该仓库包含计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设计模式、架构、校招社招分享等核心知识点,欢迎star~
程序员大彬赞 4阅读 1k
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。