FLASK——flask_sqlalchemy db.DateTime 字段保存毫秒/微秒(.000000)

问题描述:

数据库中时间字段未保存微秒部分。

from app import db
from datetime import datetime


class User(db.Model):
    __tablename__ = 'user'
    userId = db.Column(db.BIGINT, primary_key=True, autoincrement=True, nullable=False)
    userName = db.Column(db.String(16), nullable=False, unique=True)
    passwordHash = db.Column(db.String(16), nullable=False)
    createTime = db.Column(db.DateTime, default=datetime.now, nullable=False)     

nowTime = datetime.now()           # datetime.datetime(2018, 11, 2, 19, 1, 19, 903477)
print nowTime                                             # 2018-11-02 19:03:11.471624
print datetime.strftime(nowTime, '%Y-%m-%d %H:%M:%S.%f')  # 2018-11-02 19:03:11.471624

user = User(
    userName='reidlv',
    passwordHash='this_is_a_passwordHash_string'
    createTime=nowTime
)
db.session.add(user)
db.session.commit()

user_ = User.query.filter_by(userName='reidlv').first()
print user_.createTime.strptime('%Y-%m-%d %H:%M:%S.%f')          # 2018-11-02 19:03:11

解决方法:

db.DateTime 修改为 DATETIME(fsp=6)

from app import db
from datetime import datetime
from sqlalchemy.dialects.mysql import DATETIME


class User(db.Model):
    __tablename__ = 'user'
    userId = db.Column(db.BIGINT, primary_key=True, autoincrement=True, nullable=False)
    userName = db.Column(db.String(16), nullable=False, unique=True)
    passwordHash = db.Column(db.String(16), nullable=False)
    createTime = db.Column(DATETIME(fsp=6), default=datetime.now, nullable=False)

以上,问题解决。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值