flask mysql 例子_Flask动态连接数据库及动态实例表模型

这次遇到的需求有些奇葩,以前几乎没有遇到过。

根据需求,我需要先从主库读取各种配置信息,拿到必要的参数后,访问API拿到数据,再根据配置写入到指定的N个数据中,N大于50。

你可以理解为省教育局下发一份红头文件,然后全省N家学校都需要进行贯彻执行。

和普通的数据库操作不同,这次的需求,涉及以下3个难点:

“N”个库的ip地址、用户名、密码等信息都是保存于那一个主库里的,也就是说我们要为每一个数据库分别创建不同的,动态的连接。

每个数据库里都有结构相同但表名不同的类似“aaa$user”这种表,也就是说如果按照平常的,一个表写一个model类(假设有6个)的话,再假设N=50,那这里需要写300个模型。

每张表的字段名,由于历史原因,并不符合我们的编码规范,比如“[student name_]”这种带方括号和空格的字段名。这种名字也不能直接在模型里作为属性,因为语法不予许。

唉,我可太难了,o(╥﹏╥)o 但收了客户的钱,再硬的骨头,也得硬着头皮啃。

1. 动态连接数据库

flask_sqlalchemy的官方文档里提到了可以在配置文件里通过定义SQLALCHEMY_BINDS字典的方式来实现对多个数据库的访问。

SQLALCHEMY_BINDS字典的值为一个短的自定义key和一个连接字符串的组合。类似这样:

# settings.py

SQLALCHEMY_DATABASE_URI = "mysql+pymysql://root:123456@127.0.0.1:3306/school_board?charset=utf8"

SQLALCHEMY_BINDS = {

'school1': "mysql+pymysql://root:123456@127.0.0.1:3306/school1?charset=utf8"

}

这样还不行,这个短的key还需要定义在模型里,也就是说,需要跨数据库访问的表要和这个key发生绑定。举例:

# class.py

class Class(db.Model):

__tablename__ = "class"

__bind_key__ = "scho

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值