Flask-SQLAlchemy数据CURD

添加数据

  1. 实例化类,创建表数据
  2. 将实例添加到 session(add)
  3. 提交更新 (commit)
  4. 关闭 session
# 新增表数据,需要导入 User 类,进行实例化
user1 = User(id=1, username="张三", email="123@123.com")
# 将数据提交到session
db.session.add(user1)
# 将数据提交到commit
db.session.commit()
# 关闭 session
db.session.close()

批量数据添加

  1. 多次实例化类,创建多条表数据
  2. 将多个实例依次添加到 session 中(add)或者一次性添加到 session 中(add_all)
  3. 提交更新 (commit)
  4. 关闭 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()

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Xian&33

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值