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
    评论
使用flask-sqlalchemy进行增删改查操作非常方便。下面是一些示例代码来说明如何使用flask-sqlalchemy进行增删改查操作: 1. 增加数据: 使用模型类的构造函数创建一个新的对象,并将其添加到数据库会话中,然后使用会话的`add()`方法将其添加到数据库中。 示例代码如下: ``` from flask_sqlalchemy import SQLAlchemy db = SQLAlchemy() class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(80), unique=True) email = db.Column(db.String(120), unique=True) user = User(username='John', email='john@example.com') db.session.add(user) db.session.commit() ``` 2. 删除数据: 使用模型类的`query`属性和`filter_by()`方法来筛选要删除的数据,并使用会话的`delete()`方法将其从数据库删除。 示例代码如下: ``` user = User.query.filter_by(username='John').first() db.session.delete(user) db.session.commit() ``` 3. 修改数据: 使用模型类的`query`属性和`filter_by()`方法来筛选要修改的数据,并通过修改对象的属性来更新数据。 示例代码如下: ``` user = User.query.filter_by(username='John').first() user.email = 'new_email@example.com' db.session.commit() ``` 4. 查询数据: 使用模型类的`query`属性和各种查询方法来检索数据,例如`all()`方法获取所有数据,`filter_by()`方法根据条件筛选数据等。 示例代码如下: ``` users = User.query.all() # 获取所有用户数据 user = User.query.filter_by(username='John').first() # 根据用户名获取用户数据 ``` 这些是使用flask-sqlalchemy进行增删改查操作的基本示例。你可以根据需要进行调整和扩展来实现特定的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值