这次遇到的需求有些奇葩,以前几乎没有遇到过。
根据需求,我需要先从主库读取各种配置信息,拿到必要的参数后,访问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