Flask-SQLAlchemy直接用sql或Join查询出Row对象处理

在使用Flask-SQLAlchemy时,经常需要直接用sql语句,或有时需要Join联合多表查询,此时返回的结果SQLAlchemy不会自动转换为dict类型,而是内部使用的Row或RowProxy类型,在对这些数据进行Json转换,或返回给前端处理时系统会报错:

File “C:\Python\lib\json\encoder.py”, line 179, in default

raise TypeError(f’Object of type {o.class.name} ’

TypeError: Object of type Row is not JSON serializable

一、原因

由于直接使用sql特别是join多个表时,系统无法使用model定义的表对象表结果自动进行转换,而是直接返回Row对象的List,这个象的数据如下图所示:
在这里插入图片描述

二、解决方法

我在网上找了很长时间,没有找到直接可用的函数或解决方,只能对数据结构进行研究,自己写了一个把Row List转换为Dict List的方法,具体如 代码:

# 进接读取数据库,或者多表读取时,返回的是RowList,需要把row list转换为dict list
def row_to_dict(row_list):
    result = []
    for row in row_list:
        row_value = {}
        for field in row.keys():
            data = row[field]
            if isinstance(data, datetime.datetime):
                data = data.strftime("%Y-%m-%d %H:%M:%S")
            elif isinstance(data, datetime.date):
                data = data.strftime('%Y-%m-%d')
            elif isinstance(data, datetime.time):
                data = data.isoformat()
            elif isinstance(data, decimal.Decimal):
                data = float(data)

            row_value.update({field: data})
        result.append(row_value)
    return result

三、SQLAlchemy多表查询实现方法

下面是多表而查询实现代码:

if stock_code:        # 多表查询不能用标准的query,返回的结果因为不是model中的对像,不能自己处理为标准的dct,需要将Row对象转为dict
stocks_score = StocksScoreGr.query.with_entities(StocksScoreGr.security_code, StocksScoreGr.scores,
                                                 StockBasic.security_name_abbr, StocksScoreGr.fx_date). \
filter(StocksScoreGr.security_code == stock_code).join(StockBasic,StocksScoreGr.security_code ==
                                                       StockBasic.security_code) \
  .order_by(StocksScoreGr.scores.desc()).paginate(page, pagesize)

result = row_to_dict(stocks_score.items)
res = {'page': stocks_score.page, 'pages': stocks_score.pages, 'data': json.dumps(result)}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值