访问上述两个视图函数后,数据库中添加了对应的数据,如下所示:
上面给roles表中添加了五条数据,下面这个视图函数给users表添加一条数据,关联roles表。
添加用户表数据
@app.route("/addUser")
def addUser():
user = User(username = “admin1”, password=“admin”, role_id=6)
db.session.add(user);
db.session.commit();
return “添加成功”
上面视图函数中是直接给出的roles表中的id值的,开发中可以根据某一属性查询出roles某一条数据进行关联。访问视图函数后,效果如下:
查询全部结果
定义一个视图查询出roles表中的所有数据。
查询表中全部数据
@app.route("/findAll")
def findAll():
返回一个列表,all()函数返回所有结果
result = Role.query.all();
《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》
【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享
(result)
for item in result:
print(item.id, item.name)
return “查询成功”
查询结果如下:
上述中查询使用了all()函数,返回查询的所有结果,下表是SQLAlchemy查询一些常用的函数。
| 方法 | 说明 |
| — | — |
| all() | 以列表形式返回查询的所有结果 |
| first() | 返回查询的第一个结果,如果没有结结果,则返回None |
| frist_or_404 | 返回查询的第一个结果,如果没有结果,则重则请求,返回404错误响应 |
| get() | 返回指定主键对应的行,如果没有对应的行,则返回None |
| get_or_404 | 返回指定主键对应的行,如果没找到指定的主键