flask框架函数中切换数据库和日期过滤

背景:falsk 框架项目,我想在实际运行的函数中切换另外一个数据库,获取数据用。

问题:数据库已经在__init__中初始化好了,实际使用的时候是否需要重连新数据库呢??

解决方式:
不需要重连,SQLAlchemy直接通过配置修改就可以了:
直接在需要切换的地方用:

        app.config['SQLALCHEMY_BINDS'] = {'online': 'mysql://user:password@ip:port/databasename',
        "datactx": "mysql://user:password@ip:port/databasename"}

然后你实际要用哪个数据库哪个表,在model定义中指定字段来绑定数据库和表就行:

class DataFreInfo(SurrogatePK, Model):
    """data_freinfo"""
    __bind_key__ = "datactx"
    __tablename__ = 'data_frequency'
    target_id = db.Column(db.Integer, nullable=False)
    time_stamp = db.Column(db.DateTime, nullable=False,
                            default=datetime.now)

然后你直接用就行了:

        data_fre = DataFreInfo.query.filter_by(
            data_id=data_id,
        ).filter(
            DataFreInfo.create_time.between(start_time, end_time)
        ).order_by(DataFreInfo.id.desc()).first()

这里关键字过滤一般用:filter_by
特定条件用: filter就好

cls.query.filter(类名.属性名 条件操作符 条件) 过滤特定条件,返回的是query对象
cls.query.filter_by(关键字参数对) 单条件查询,条件必须关键字参数

小记如上,人一定要保持学习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值