背景: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(关键字参数对) 单条件查询,条件必须关键字参数
小记如上,人一定要保持学习。