Flask_使用flask_marshmallow序列化数据

代码如下:

from flask import Flask
from flask_marshmallow import Marshmallow
from flask_sqlalchemy import SQLAlchemy
from marshmallow import fieldsapp = Flask(__name__)
app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:123456@192.168.3.66:3306/tms?charset=utf8mb4"
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = Falsedb = SQLAlchemy()
db.init_app(app)ma = Marshmallow()
ma.init_app(app)# ========================= 模型类 =========================================================
class User(db.Model):__tablename__ = 'admin_user'id = db.Column(db.Integer, primary_key=True, autoincrement=True, comment='用户ID')username = db.Column(db.String(20), comment='用户名')realname = db.Column(db.String(20), comment='真实名字')remark = db.Column(db.String(255), comment='备注')dept_id = db.Column(db.Integer, comment='部门id')# ========================= 序列化类 =========================================================
class UserSchema(ma.Schema):userId = fields.Integer(attribute="id")     # 变量名称为序列化后的key名称,attribute为数据库的字段名称,若变量名称和数据库字段名称一致,可缺省attributeusername = fields.Str()realname = fields.Str()@app.route("/")
def index():users = db.session.query(User).all()print("序列化的模型类")print("入参数据", users)schema = UserSchema(many=True)ret = schema.dump(users)print("出参数据", ret)return retif __name__ == '__main__':app.run(debug=True, host="localhost", port=8000)

执行结果:

联表序列化,后续研究研究在给大家说说。

源码等资料获取方法

各位想获取源码等教程资料的朋友请点赞 + 评论 + 收藏,三连!

三连之后我会在评论区挨个私信发给你们~

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/3264.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络协议栈介绍

一、网络协议栈 网络协议栈是计算机网络中的重要组件,负责处理网络数据包在不同协议层之间的传递和处理。常见的网络协议栈有以下几种: 1. 基于内核的协议栈:操作系统内核实现的网络协议栈,如Linux的TCP/IP协议栈。 实现原理&a…

Apikit 自学日记:私有云才有的测试文件库功能,该如何使用呢

在 APIkit 的私有云版本中,提供了测试文件库功能。不过目前该功能仅供私有云产品,线上SaaS产品不提供测试文件库功能 API自动化测试中可以添加文件参数。在这里统一管理所有测试文件。 在测试文件库界面,点击上传文件: 在私有云产…

ORACLE的循环

ORACLE的循环 LOOP循环 declare num number; begin num:1; loopdbms_output.put_line(yes);IF num > 10 THENEXIT;END IF;num : num 1; end loop; end;WHILE 循环 declare num stu_info.id%type; beginnum:0;while num<10 loopdbms_output.put_line(num);num:num1;en…

opencv -12 图像运算之按 《位或》 运算(图像融合图像修复和去除)

位或运算 或运算的规则是&#xff0c;当参与或运算的两个逻辑值中有一个为真时&#xff0c;结果就为真。其逻辑关系可以类比为如图 所示的并联电路&#xff0c;两个开关中只要有任意一个闭合时&#xff0c;灯就会亮。 3-5 对参与或运算的算子的不同情况进行了说明&#xff0c;…

7月19日,每日信息差

1、奔驰召回3.2万辆进口汽车&#xff0c;ESP存安全隐患.本次召回范围内车辆由于软件问题&#xff0c;车身电子稳定系统&#xff08;ESP&#xff09;内部监控程序可能会在驾驶循环开始时错误地判定故障&#xff0c;导致车辆动态控制系统的功能受限&#xff0c;存在安全隐患 2、…

Linux操作系统升级低版本的OpenSSH到9.3的高版本

OpenSSH 9.3之前的版本存在各种各样的安全漏洞&#xff0c;为此&#xff0c;我们需要将OpenSSH升级到最新的9.3的版本。 执行&#xff1a;ssh -V&#xff0c;我们可以查看当前的openssh版本 为了避免升级过程中出现意外而导致服务器无法正常使用&#xff0c;建议操作前先对服务…

力扣 406. 根据身高重建队列

题目来源&#xff1a;https://leetcode.cn/problems/queue-reconstruction-by-height/description/ C题解1&#xff1a;分别对h和k两个维度进行考虑&#xff0c;我这里是优先考虑k值&#xff0c;k值相同的时候h小的排前面。然后再一一遍历&#xff0c;对于people[i]&#xff0c…

Nacos报错Could not resolve placeholder ‘order.name‘ in value “${order.name}“怎么解决?

出现这个原因有两个&#xff1a; 1.首先在Nacos配置中心&#xff0c;写入yml配置文件的数据和后端服务在取数据的时候名称不一致 如下图&#xff0c;现在我的配置中心为order-service 看看其中的文件内容信息&#xff1a; 再看看后端是怎么取的&#xff1a; 看出上面错误了吗…

西安---高时空分辨率、高精度一体化预测技术之风、光、水能源自动化预测技术应用

能源是国民经济发展和人民生活必须的重要物质基础。在过去的200多年里&#xff0c;建立在煤炭、石油、天然气等化石燃料基础上的能源体系极大的推动了人类社会的发展。但是人类在使用化石燃料的同时&#xff0c;也带来了严重的环境污染和生态系统破坏。近年来&#xff0c;世界各…

vue写车牌号 自定义键盘

vue写车牌号自定义键盘 <template><div><div class"content-wrapper"><div class"content-top-wrapper"><van-radio-group v-model"radioCarType"><van-radio name"1">蓝牌<imgslot"icon…

什么是渲染?一文看懂,萌新赶紧收藏码住!

十四五规划提出“加快数字化发展&#xff0c;建设数字中国”&#xff0c;数字技术的快速发展&#xff0c;从起初的内容创建到最终的效果呈现&#xff0c;都离不开渲染技术。目前&#xff0c;渲染技术被广泛应用于教育、医疗、影视动画、建筑设计等多个领域。它能有效满足用户对…

ffmpeg的函数调用知识点

av_dump_format 打印的内容是什么意思&#xff1f; av_dump_format 会打印出AVFormatContext的内容&#xff0c;打印的内容是什么意思&#xff1f; 我们使用av_dump_format打印出如下信息&#xff1a; Input #0, mov,mp4,m4a,3gp,3g2,mj2, from https://demo.com/BigBuckBunny.…

Python版Day45

70. 爬楼梯 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 完全背包解法 注意这是求排列问题&#xff0c;1、2步 和 2、1步都是上三个台阶&#xff0c;但是这两种方法不一样 先遍历背包再遍历物…

关于微信小程序 textarea 遇到的坑

1、获取到焦点 键盘弹出时 页面上拉 解决方法 设置adjust-position为false 参考官网&#xff1a;textarea | uni-app官网 textarea的abjust-position属性 例子&#xff1a;注意加&#xff1a; <textarea :adjust-position"false" /> 2、键盘弹出的时…

Java版企业工程项目管理系统源码+java版本+项目模块功能清单+spring cloud +spring boot

工程项目各模块及其功能点清单 一、系统管理 1、数据字典&#xff1a;实现对数据字典标签的增删改查操作 2、编码管理&#xff1a;实现对系统编码的增删改查操作 3、用户管理&#xff1a;管理和查看用户角色 4、菜单管理&#xff1a;实现对系统菜单的增删改查操…

ArcGIS、ENVI、InVEST、FRAGSTATS等多技术提升数据分析能力

专题一、空间数据获取与制图 1.1 软件安装与应用讲解 1.2 空间数据介绍 1.3海量空间数据下载 1.4 ArcGIS软件快速入门 1.5 Geodatabase地理数据库 专题二、ArcGIS专题地图制作 2.1专题地图制作规范 2.2 空间数据的准备与处理 2.3 空间数据可视化&#xff1a;地图符号与…

在第二代SpringCloud中配置网关组件

我们接着上次的微服务的项目继续搭建网关组件: 搭建微服务项目 前提准备: 1.打开nacos服务注册中心,在浏览器通过这地址访问 http://10.48.185.7:8848/nacos/index.html 2.启动page和product的微服务 1.新建一个网关的项目 2.导入pom依赖 <!-- Spring Boot父启动器…

美团面试官:那你讲一讲Vuex吧

给大家推荐一个实用面试题库 1、前端面试题库 &#xff08;面试必备&#xff09; 推荐&#xff1a;★★★★★ 地址&#xff1a;前端面试题库 前言 周一接到了美团的一面&#xff0c;面试官人很好&#xff0c;基本都是围绕着简历来问&#xff0c;下面就是我重新…

DBeaver连接华为高斯数据库 DBeaver连接Gaussdb数据库 DBeaver connect Gaussdb

DBeaver连接华为高斯数据库 DBeaver连接Gaussdb数据库 DBeaver connect Gaussdb 一、概述 华为GaussDB出来已经有一段时间&#xff0c;最近工作中刚到Gauss数据库。作为coder&#xff0c;那么如何通过可视化工具来操作Gauss呢&#xff1f; 本文将记录使用免费、开源的DBeaver来…

【kubernetes系列】Kubernetes之资源配置范围管理LimitRange

概述 在默认情况下&#xff0c;Kubernetes不会对Pod加上CPU和内存限制&#xff0c;这意味着Kubernetes系统中任何Pod都可以使用其所在节点的所有可用的CPU和内存。在之前的章节https://blog.csdn.net/margu_168/article/details/131786000分享了针对集群中某个pod的资源限制&a…