sqlalchemy实现时间列自动更新教程
作者:水痕01 发布时间:2021-08-18 20:12:58
标签:sqlalchemy,时间列,更新
一、使用场景需求
1、在实际项目开发过程中,用户可以操作的数据,我们往往会新增一个字段,来保存用户最后一次修改时间
2、一些系统中,我们需要存储用户最后一次登录时间,来统计用户的活跃度
二、 在sqlalchemy中常规的做法
1、数据模型
import datetime
from uuid import uuid4
from sqlalchemy import Column, Integer, String, DateTime, Boolean
from sqlalchemy_demo.connect import Base
class UserModule(Base):
"""
创建一个用户的数据模型
"""
__tablename__ = 'user'
uuid = Column(String(36), unique=True, nullable=False, default=lambda: str(uuid4()), comment='uuid')
id = Column(Integer, primary_key=True, autoincrement=True, comment='用户id')
user_name = Column(String(30), nullable=False, unique=True, comment='用户名')
password = Column(String(64), nullable=False, comment='用户密码')
createtime = Column(DateTime, default=datetime.datetime.now, comment='创建时间')
updatetime = Column(DateTime, default=datetime.datetime.now, comment='修改时间')
is_lock = Column(Boolean, default=False, nullable=False, comment='是否锁住用户')
2、每次更新数据的时候,需要手动插入时间字段,来确保updatetime这个时间字段才会更新
三、使用自动更新数据
基于上面手动插入时间字段,在开发过程中很不方便,我们需要的是类似django中修改数据,该列会自动更新
1、导包
from uuid import uuid4
from sqlalchemy import Column, Integer, String, DateTime, Boolean, TIMESTAMP, func
from sqlalchemy.orm import relationship
from sqlalchemy_demo.connect import Base
2、定义数据模型
class UserModule(Base):
"""
创建一个用户的数据模型
"""
__tablename__ = 'user'
uuid = Column(String(36), unique=True, nullable=False, default=lambda: str(uuid4()), comment='uuid')
id = Column(Integer, primary_key=True, autoincrement=True, comment='用户id')
user_name = Column(String(30), nullable=False, unique=True, comment='用户名')
password = Column(String(64), nullable=False, comment='用户密码')
createtime = Column(DateTime, server_default=func.now(), comment='创建时间')
# onupdate设置自动更改
updatetime = Column(DateTime, server_default=func.now(), onupdate=func.now(), comment='修改时间')
is_lock = Column(Boolean, default=False, nullable=False, comment='是否锁住用户')
3、接下来的创建表与增删改查都一样的。
补充知识:Flask-SQLALchemy对表中数据按时间进行统计
例如表的结构如下:
class Status(db.Model):
id = db.Column(db.Integer, primary_key=True)
submit_time = db.Column(db.DateTime, default=datetime.now())
其中,Status表接受用户的提交,现在想对用户的提交情况按时间进行统计。例如过去24小时,每小时的提交次数;过去12个月,每个月的提交次数。
python代码实现查询如下:
from datetime import datetime, timedelta
NOW = datetime.utcnow()
last_24h_submits_count = []
for h in xrange(1,25):
count = session.query(Status).filter(Status.submit_time.between(NOW - timedelta(seconds=h*3600-1), NOW - timedelta(hours=h-1))).count()
last_24h_submits_count.append(count)
来源:https://blog.csdn.net/kuangshp128/article/details/85700701
0
投稿
猜你喜欢
- 最近写程序需要从文件中读取数据,并把读取的数据转换成向量。查阅资料之后找到了读取csv文件和txt文件两种方式,下面结合自己的实验过程,做简
- Go语言集成开发环境之VS Code安装使用VS Code是微软开源的一款编辑器,插件系统十分的丰富。下面介绍如何用VS Code搭建go语
- 一、前言很多时候,我们都有远程控制电脑的需求。比如正在下载某样东西,需要让电脑在下载完后关机。或者你需要监控一个程序的运行状况等。今天我们就
- 一对多(ForeignKey)class ForeignKey(ForeignObject): def __init__(sel
- python中安装包的方式有很多种:源码包:python setup.py install在线安装:pip install 包名(linux
- Keras中构建RNN的重要函数1、SimpleRNNSimpleRNN用于在Keras中构建普通的简单RNN层,在使用前需要import。
- 最简单的:<textarea name="A" cols="45" rows="2&
- <% Function FileCounter(counter_file) Dim fs,txt,fi
- 创建与打开站点启动FrontPage XP,选择菜单“文件/新建”,再单击“网页或站点”命令选项。在“新建网页或站点”任务窗格
- 这些包可以独立使用,也可以与其他包一起使用以满足复杂的业务需求。Integration Services 可以提取和转换来自多种源(如 XM
- 我认为多选列表具有完美的功能——只需按下Ctrl键,同时点击鼠标从列表中选择多个项目。以下是一个典型的多选列表框: 上面那个列表框
- 本文例举了ASP实例关于ASP与ACCESS链接的两种方式。<%dim dd,connstrdd="data.mdb&quo
- PHP PDO 预处理语句与存储过程很多更成熟的数据库都支持预处理语句的概念。什么是预处理语句?可以把它看作是想要运行的 SQL 的一种编译
- 总结常用基本点如下: 1、触发器有两种类型:数据定义语言触发器(DDL触发器)和数据操纵语言触发器(DML触发器)。 DDL触发器:在用户对
- 往列表头部和尾部添加元素往头部添加元素list.insert(index,new_element)@@@index为新元素的插入位置,当in
- 五子棋游戏相信大部分人都玩过,今天我们用python来实现一次具体代码可以访问我的GitHub地址获取构建五子棋棋盘from collect
- 如何使用MsChart?MsChart是微软出品的一款功能强大的制作图表工具,用它可以很方便的建立各种图表。下面我们举例来说明:submit
- ./当前目录 /网站主目录 ../上层目录 ~/网站虚拟目录 如果当前的网站目录为E:\wwwroot 应用程序虚拟目录为E:\wwwroo
- 问题:1.一个销售系统,设有各级代理商,每个代理商的表是这样设计的 数据库结构表1: 代理商资料表[id]
- 对于python的tkinter库来说,如果需要弹出文件选择框,我们需要引入一下tkinter.filedialog包,让用户直观地先择一个