sqlalchemy——@listens_for

  • 问:sqlalchemy如何实现:表中指定数据更新时,其time字段自动更新?
  • 答:使用listens_for 装饰器来注册事件监听器,确保在项目数据更新时触发相应的处理逻辑。

示例代码如下:

# coding: utf-8
import datetime

from sqlalchemy.event import listens_for
from sqlalchemy.orm import declarative_base
from sqlalchemy import Column, String

Base = declarative_base()
'''
    项目表
'''

class ProjectTable(Base):
    __tablename__ = 'project'
    # 项目id
    id = Column(String(32), primary_key=True)
    # 项目名称
    name = Column(String(255))
    # 项目说明
    explain = Column(String(255))
    # 项目类型
    type = Column(String(20))
    # 更新时间
    time = Column(String(20), default=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"))

    def __repr__(self):
        table = "project(id={}, name={}, explain={},time={},type={})"
        return table.format(self.id, self.name, self.explain, self.time, self.type)

    # 将查询结果转换为Json
    def to_json(self):
        _dict = self.__dict__
        if "_sa_instance_state" in _dict:
            del _dict["_sa_instance_state"]
        return _dict
# 添加监听,当数据更新时,自动更新time字段
@listens_for(ProjectTable, 'before_update')
def before_update_listener(mapper, connection, target):
    target.time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-02-01 14:12:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-01 14:12:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-01 14:12:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-01 14:12:01       18 阅读

热门阅读

  1. 《Docker极简教程》--前言--Docker的简介

    2024-02-01 14:12:01       30 阅读
  2. SpringMVC校验注解不生效

    2024-02-01 14:12:01       32 阅读
  3. C++的学习记录

    2024-02-01 14:12:01       36 阅读
  4. 【Midjourney】新手指南:参数设置

    2024-02-01 14:12:01       29 阅读
  5. 【数据结构】单调队列

    2024-02-01 14:12:01       36 阅读
  6. C语言结构体

    2024-02-01 14:12:01       33 阅读
  7. 图论——最短路径

    2024-02-01 14:12:01       24 阅读
  8. JUnit

    JUnit

    2024-02-01 14:12:01      31 阅读
  9. vue登陆修改密码等加密(禁止明文传输)

    2024-02-01 14:12:01       28 阅读
  10. Python 将文本转换成语音播放 pyttsx3

    2024-02-01 14:12:01       24 阅读
  11. 【GPU驱动开发】- GPU架构流程

    2024-02-01 14:12:01       24 阅读