本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/23442
添加数据(create)
单条数据添加:
if __name__ == '__main__':
"""
1. 实例化类,创建表数据
2. 将实例添加到 session(add)
3. 提交更新 (commit)
4. 关闭 session
"""
user = User(username="hogwarts", email="1254236457@qq.com")
# 将数据提交到session
with app.app_context():
db.session.add(user)
# 将数据提交到commit
db.session.commit()
# 关闭 session
db.session.close()
批量数据添加:
"""
多条数据添加
1. 多次实例化类,创建多条表数据
2. 将多个实例依次添加到 session(add)中或者一次性添加到 session 中(add_all)
3. 提交更新 (commit)
4. 关闭 session
"""
user2 = User(username="joker", email="125@qq.com")
user3 = User(username="joker4234", email="125wery@qq.com")
# 将数据提交到session
with app.app_context():
# 第一种,依次添加
# db.session.add(user2)
# db.session.add(user3)
# 第二种,批量添加,add_all需要传入一个列表,列表中存放数据对象
db.session.add_all([user2,user3])
# 将数据提交到commit
db.session.commit()
# 关闭 session
db.session.close()
读取数据(read)
查询表中所有数据:
类名.query.all()
# 读取全部数据
with app.app_context():
res = User.query.all()
for r in res:
print(r.username, r.email)
查询条件:
- 单条数据:类名.query.filter_by(条件).first()
- 多条数据:类名.query.filter_by(条件).all()
# 查询多条数据
with app.app_context():
res = User.query.filter_by(age=20).all()
for r in res:
print(r.username, r.email)
# 查询单条数据
with app.app_context():
res = User.query.filter_by(age=20).first()
print(res.username, res.email)
如果有多个查询条件,直接在后面用filter_by方法添加查询条件即可
修改数据(update)
"""
方法一:
1. 首先查询出来需要的数据
2. 对查询出来的数据对象进行属性修改
3. 提交session
"""
with app.app_context():
res = User.query.filter_by(age=21).first()
res.username = "霍格沃兹"
db.session.commit()
db.session.close()
"""
方法二:
给定查询条件查询后,直接用update()方法进行修改
提交session
"""
with app.app_context():
res = User.query.filter_by(age=21).update({'email': "1245@qq.com"})
db.session.commit()
db.session.close()
删除数据(delete)
"""
方法一:
1. 首先查询出来需要的数据
2. 对查询出来的数据对象进行属性修改
3. 提交session
"""
with app.app_context():
res = User.query.filter_by(age=21).first()
res.username = "霍格沃兹"
db.session.commit()
db.session.close()
"""
方法二:
给定查询条件查询后,直接用update()方法进行修改
提交session
"""
with app.app_context():
res = User.query.filter_by(age=21).update({'email': "1245@qq.com"})
db.session.commit()
db.session.close()
推荐学习
【霍格沃兹测试开发】7天软件测试快速入门带你从零基础/转行/小白/就业/测试用例设计实战
【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (上集)
【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (下集)
【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(上集)
【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(下集)
【霍格沃兹测试开发】精品课合集/ 自动化测试/ 性能测试/ 精准测试/ 测试左移/ 测试右移/ 人工智能测试
【霍格沃兹测试开发】腾讯/ 百度/ 阿里/ 字节测试专家技术沙龙分享合集/ 精准化测试/ 流量回放/Diff
【霍格沃兹测试开发】Pytest 用例结构/ 编写规范 / 免费分享
【霍格沃兹测试开发】JMeter 实时性能监控平台/ 数据分析展示系统Grafana/Docker 安装
【霍格沃兹测试开发】接口自动化测试的场景有哪些?为什么要做接口自动化测试?如何一键生成测试报告?
【霍格沃兹测试开发】面试技巧指导/ 测试开发能力评级/1V1 模拟面试实战/ 冲刺年薪百万!
【霍格沃兹测试开发】腾讯软件测试能力评级标准/ 要评级表格的联系我
【霍格沃兹测试开发】Pytest 与Allure2 一键生成测试报告/ 测试用例断言/ 数据驱动/ 参数化
【霍格沃兹测试开发】App 功能测试实战快速入门/adb 常用命令/adb 压力测试
【霍格沃兹测试开发】阿里/ 百度/ 腾讯/ 滴滴/ 字节/ 一线大厂面试真题讲解,卷完拿高薪Offer !
【霍格沃兹测试开发】App自动化测试零基础快速入门/Appium/自动化用例录制/参数配置
【霍格沃兹测试开发】如何用Postman 做接口测试,从入门到实战/ 接口抓包(最新最全教程)
【霍格沃兹测试开发】6 小时轻松上手功能测试/ 软件测试工作流程/ 测试用例设计/Bug 管理
【霍格沃兹测试开发】零基础小白如何使用Postman ,从零到一做接口自动化测试/ 从零基础到进阶到实战
【霍格沃兹测试开发】建议收藏全国CCF 测试开发大赛Python 接口自动化测试赛前辅导 / 项目实战
更多软件测试开发视频教程点此
软件测试职业发展
零基础入门
测试必备编程篇
自动化测试
性能测试
测试管理
工程效能篇
面试求职篇
软件测试的面试宝典,内含一线互联网大厂面试真题、面试技巧、软件测试面试简历指导,免费领取!