falsk模型-flask_sqlalchemy增删改查

1、增、删、改

python 复制代码
@home_bp.route('/useradd')
def user_add():
    users = []
    for i in range(10,20):
        user = User()
        user.name = '冰冰' + str(i)
        user.age = 20+i
        users.append(user)
    try:
        db.session.add_all(users)
        db.session.commit()
        return jsonify({'code':1,'info':'success'})
    except Exception as e:
        db.session.rollback()
        return jsonify({'code':0,'info':str(e)})

python 复制代码
#删
@home_bp.route('/userdel')
def user_del():
    user = User.query.first() # 查询第一条数据
    db.session.delete(user)
    try:
        db.session.commit()
        return jsonify({'code':1,'info':'success'})
    except Exception as e:
        db.session.rollback()
        return jsonify({'code':0,'info':str(e)})

python 复制代码
# 改:修改数据
#    找到要修改的数据,然后修改
@home_bp.route('/userupdate/')
def user_update():
    u = User.query.first()  # 查询第一条数据
    u.age = 1000
    db.session.commit()
    return jsonify({'code':1,'info':'success'})

2、查

(1)all(): 返回所有数据,返回列表

python 复制代码
    users = User.query.all()

    print(users, type(users))  # <class 'list'>

    print(users[0].name)  #冰冰01

    print(User.query, type(User.query))  # <class 'flask_sqlalchemy.query.Query'>

(2) filter() : 过滤,得到查询集,类似SQL中的where

python 复制代码
    users = User.query.filter(User.age==20)
    users = User.query.filter(User.age>20)  # 可以用于非等值操作
    print(list(users))  # [冰冰20]

(3) count(): 统计查询集(User.query.filter()中的数据条数

python 复制代码
     users = User.query.filter()
     print(users.count())  # 20

(4)filter_by() : 用于等值操作的过滤

python 复制代码
users = User.query.filter_by(age=20)

(5)get():查询到对应主键的数据对象

python 复制代码
    user = User.query.get(8)
    print(user, type(user))  # User对象 <class 'App.models.User'>
    print(user.name, user.age)  # 获取数据的属性

(6)limit() : 前几条:offset() : 跳过前几条

python 复制代码
   users = User.query.offset(3).limit(4)
   print(list(users))

(7)排序

复制代码
    users = User.query.order_by('age')  # 升序
    users = User.query.order_by(desc('age'))  # 降序

(8)and_,or_,not_

python 复制代码
     users = User.query.filter(User.age>20, User.age<25)  # 且,常用
     users = User.query.filter(and_(User.age>20, User.age<25))  # 且
     users = User.query.filter(or_(User.age>25, User.age<20))  # 或
     users = User.query.filter(not_(or_(User.age>25, User.age<20)))  # 非

(9) 模糊查找,类似SQL中的like

python 复制代码
users = User.query.filter(User.name.contains('3'))

(10) in_(): 其中之一

python 复制代码
users = User.query.filter(User.age.in_([10, 20, 30, 40, 50]))

(11) startswith() : 以某子串开头,endswith() : 以某子串结尾

python 复制代码
    users = User.query.filter(User.name.startswith('冰'))  #
    users = User.query.filter(User.name.endswith('2'))

(12)gt: 大于

python 复制代码
users = User.query.filter(User.age.__gt__(25))
相关推荐
梦想画家1 小时前
基于PyTorch的时间序列异常检测管道构建指南
人工智能·pytorch·python
PythonFun2 小时前
OCR图片识别翻译工具功能及源码
python·ocr·机器翻译
虫师c3 小时前
Python浪漫弹窗程序:Tkinter实现动态祝福窗口教程
python·tkinter·动画效果·gui编程·弹窗效果
灯火不休时4 小时前
95%准确率!CNN交通标志识别系统开源
人工智能·python·深度学习·神经网络·cnn·tensorflow
鬼火儿4 小时前
SpringBoot】Spring Boot 项目的打包配置
java·后端
cr7xin4 小时前
缓存三大问题及解决方案
redis·后端·缓存
deephub4 小时前
FastMCP 入门:用 Python 快速搭建 MCP 服务器接入 LLM
服务器·人工智能·python·大语言模型·mcp
南宫乘风5 小时前
基于 Flask + APScheduler + MySQL 的自动报表系统设计
python·mysql·flask
番石榴AI5 小时前
基于机器学习优化的主图选择方法(酒店,景点,餐厅等APP上的主图展示推荐)
图像处理·人工智能·python·机器学习
qq7422349845 小时前
Python操作数据库之pyodbc
开发语言·数据库·python