IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Flask操作多个数据库 -> 正文阅读

[Python知识库]Flask操作多个数据库

config.py:

SQLALCHEMY_BINDS = {
    "db1": "mysql+pymysql://db_user1:db_pwd1@db_host1:db_port1/db_name1?charset=utf8",
    "db2": "mysql+pymysql://db_user2:db_pwd2@db_host2:db_port2/db_name2?charset=utf8",
}



models.py:

def dynamic_model(bind_key, model_n):
    properties = {
        "__tablename__" = model_n.__tablename__,
        "__bind_key__" = bind_key
    }
    for col in dir(model_n):
        if col.startswith('_'):
            continue
        properties[col] = getattr(model_n, col)
    model = type(model_n.__tablename__, (db.Model,), properties)
    return model

自定义序列化:

class Serialize:
    def __init__(self, model):
        self.query = model.query
        self.model = model
        self.columns = []
        self.page_size = request.args.get('page_size', type=int, default=10)
        self.current_page = request.args.get('page', default=1, type=int)
        self.start = (self.current_page - 1) * self.page_size
        self.end = self.start + self.page_size
        self.field_func_map = {}

    def field(self, *columns):
        self.columns = columns
        self.query = db.session.query(*[getattr(self.model, column) for column in columns])
        return self

    def search(self, **kw_map):
        for column in kw_map:
            if kw_map[column]:
                self.query = self.query.filter(
                    getattr(self.model, column).like("%{}%".format('/' + kw_map[column]), escape='/'))
        return self

    def exclude(self, **kw_map):
        for column in kw_map:
            self.query = self.query.filter(
                getattr(self.model, column) != kw_map[column])
        return self

    def custom_handle(self, **kargs):
        self.field_func_map = kargs
        return self

    def to_json(self, **kw_map):
        res = []
        for column in kw_map:
            self.query = self.query.filter(
                getattr(self.model, column) == kw_map[column])
        if self.columns:
            for q in self.query.slice(self.start, self.end):
                obj_dict = {}
                for i, c in enumerate(self.columns):
                    if c in self.field_func_map:
                        obj_dict[c] = self.field_func_map[c.name](q[i])
                    else:
                        obj_dict[c] = q[i]
                res.append(obj_dict)
        else:
            for q in self.query.slice(self.start, self.end):
                obj_dict = {}
                for c in class_mapper(q.__class__).columns:
                    if c.name in self.field_func_map:
                        obj_dict[c.name] = self.field_func_map[c.name](getattr(q, c.name))
                    else:
                        obj_dict[c.name] = getattr(q, c.name)
                res.append(obj_dict)
        return res

    def total(self):
        return self.query.count()

    def data(self, **kw_map):
        return {
            'data': self.to_json(**kw_map),
            'total': self.total(),
            'currentPage': self.current_page,
            'pageSize': self.page_size
        }

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-04-22 18:32:27  更:2022-04-22 18:32:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 18:06:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码