flask-数据库之增删改查

一、增删改

# 添加:
db.session.add(stu)
db.session.commit()

# 例:
@blue.route('/add_stu/', methods=['GET'])
def add_stu():
    if request.method == 'GET':
        # 插入数据
        stu = Student()
        stu.s_name = '火云邪神'
        db.session.add(stu)
        db.session.commit()
        return '创建学生信息成功'


# 删除操作

db.session.delete(stu)
db.session.commit()


# 修改:
db.session.add(stu) # add()方法写不写都行
db.session.commit()

# 如果觉得代码量过多可以封装一下
from datetime import datetime

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()


class Student(db.Model):


    __tablename__ = 'student'
    # Integer = INTEGER = INT
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    s_name = db.Column(db.String(10),unique=True,nullable=False)
    s_age = db.Column(db.Integer, default=20)
    s_gender = db.Column(db.Boolean, default=1)
    create_time = db.Column(db.DateTime, default=datetime.now)
    # 封装一个添加的方法
    def save(self):
        db.session.add(self)
        db.session.commit()
    # 封装一个删除的方法
    def delete(self):
        db.session.delete(self)
        db.session.commit()
    # 封装一个更新的方法
    def update(self):
    	db.session.commit()


二、查

  • filter()方法
    filter(模型名.字段==值)

或 filter_by(字段=值)

  • all()方法
    查询所有数据,结果为列表

  • first()方法
    查询filter或filter_b结果中的第一个对象

  • get()方法
    获取主键所在行的对象信息
    get()方法能获取对象,则返回,获取不到对象则为空

# filter()方法
# 查询方式一
stu = Student.query.filter(Student.s_name=='东方不败')
# 方式二
stu = Student.query.filter_by(s_name='东方不败')

# 获取第一个对象
stu = Student.query.all()[0]
print(stu)
stu = Student.query.first()
print(stu)


stu = Student.query.get(1)
print(stu)


  • 排序
    id : 升序
    -id:降序
stus = Student.query.order_by('-id').all()
stus = Student.query.order_by('id').all()
  • 分页
    offset():跳过多少个
    limit():查看多少个
stus = Student.query.all()[:4]
stus = Student.query.offset(1).limit(3).all()
  • 范围查询
    gt:>
    ge:>=
    lt:<
    le:<=
# 方式一
stus = Student.query.filter(Student.s_age.__gt__(20)).all()
# 方式二(这里支持 简写的比较运算符)
stus = Student.query.filter(Student.s_age >= 20).all()
  • 模糊查询
    contains() :包含某个内容
    startwith():以…开始
    endwith(): 以…结束

like() :
_:占位
%:任何内容

stus = Student.query.filter(Student.s_name.contains('不')).all()
stus = Student.query.filter(Student.s_name.startswith('张')).all()
stus = Student.query.filter(Student.s_name.endswith('蓉')).all()

stus = Student.query.filter(Student.s_name.like('__冲%')).all()
  • 组合查询
    filter()中可以添加多个过滤条件
stus = Student.query.filter(Student.s_name.contains('神')).filter(Student.s_age > 25).all()
stus = Student.query.filter(Student.s_name.contains('神'), Student.s_age > 25).all()

# 且 and_:默认就是且操作,可以不用写
stus = Student.query.filter(and_(Student.s_name.contains('神'), Student.s_age > 25)).all()

# 或 or_
stus = Student.query.filter(or_(Student.s_name.contains('神'), Student.s_age > 25)).all()

# 非 not_
stus = Student.query.filter(not_(Student.s_name.contains('神'))).all()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值