添加数据
- 实例化类,创建表数据
- 将实例添加到 session(add)
- 提交更新 (commit)
- 关闭 session
# 新增表数据,需要导入 User 类,进行实例化
user1 = User(id=1, username="张三", email="123@123.com")
# 将数据提交到session
db.session.add(user1)
# 将数据提交到commit
db.session.commit()
# 关闭 session
db.session.close()
批量数据添加
- 多次实例化类,创建多条表数据
- 将多个实例依次添加到 session 中(add)或者一次性添加到 session 中(add_all)
- 提交更新 (commit)
- 关闭 session
# 批量添加数据操作
user2 = User(id=2, username="张四", email="124@123.com")
user3 = User(id=3, username="张五", email="125@123.com")
# 第一种依次添加,将数据提交到session
db.session.add(user2)
db.session.add(user3)
# 第二种批量添加
db.session.add_all([user2, user3])
# 将数据提交到commit
db.session.commit()
# 端口session
db.session.close()
查询表中全部数据
- 格式:
类.query.all()
# 读取全部数据
res = User.query.all()
# 遍历数据,得到想要的字段
for rs in res:
print(rs.username, rs.email)
条件查询
- 格式:
类.query.filter_by(条件).单条或多条
单条件查询
- 查询单条数据:
类.query.filter_by(条件).first()
- 查询多条数据:
类.query.filter_by(条件).all()
# 单条数据查询
res = User.query.filter_by(gender="男").first()
print(res)
# 多条数据查询
res = User.query.filter_by(gender="男").all()
多条件查询
- 查询单条数据:
类.query.filter_by(条件).filter_by(条件)...first()
- 查询多条数据:
类.query.filter_by(条件).filter_by(条件)...all()
# 单条数据查询
res = User.query.filter_by(gender = "男").\
filter_by(username='马力').filter_by(email="aaa").\
first()
# 多条数据查询
res = User.query.filter_by(gender = "男").\
filter_by(username='马力').filter_by(email="aaa").\
all()
修改数据
- 方式一:
- 首先查询出来需要的数据
- 对查询出来的数据对象进行属性的修改
- 提交 session
- 方式二:
- 给定查询条件进行查询后,直接进行 update 操作
- 提交 session
# 数据的修改
# 第一种方式,更新某个字段
res = User.query.filter_by(id=2).first()
res.gender = "女"
# 提交
db.session.commit()
# 关闭session
db.session.close()
# 第二种方式,直接调用update方法更新行数据
res = User.query.filter_by(id=2).update({"gender": "男"})
# 提交
db.session.commit()
# 关闭session
db.session.close()
删除数据
- 方式一:
- 查询数据
- 对查询出来的数据对象进行删除操作
- 提交 session
- 方式二:
- 给定查询条件进行查询后,直接进行 delete 操作
- 提交 session
# 方式一:
# 查询数据
user = User.query.filter_by(id=1).first()
# 删除操作
db.session.delete(user)
# 提交
db.session.commit()
# 关闭session
db.session.close()
# 方式二:
# 查询结果直接删除操作
User.query.filter_by(id=1).delete()
# 提交
db.session.commit()
# 关闭session
db.session.close()