Flask数据的增删改查(CRUD)_flask删除数据自动更新

查询年龄小于17的学生信息

复制代码
Student.query.filter(Student.s_age < 17)
students = Student.query.filter(Student.s_age.__lt__(17))

模糊查询,使用like,查询姓名中第二位为花的学生信息

like '_花%',_代表必须有一个数据,%任何数据

复制代码
students = Student.query.filter(Student.s_name.like('_花%'))

筛选:

offset()

跳过3个数据

stus = Student.query.offset(3)

limit()

跳过3个数据,查询5个信息

stus = Student.query.offset(3).limit(5)

order_by()

按照id降序,升序

students = Student.query.order_by('id')

students = Student.query.order_by('-id')

复制代码
students = Student.query.order_by(desc('id'))
students = Student.query.order_by(asc('id'))

students = Student.query.order_by('id desc')
students = Student.query.order_by('id asc')

get()

#使用get,获取id=1的学生对象,get()默认接收id

拿不到值不会报错,返回空

students = Student.query.get(4)

first()

获取年龄最大的一个

stus = Student.query.order_by('-s_age').first()

逻辑运算

and_

filter(and_(条件),条件...)

复制代码
或
	or_
	filter(or_(条件),条件...)

非
	not_
	filter(not_(条件),条件...)

例子:

and_

students = Student.query.filter(Student.s_age==16,

Student.s_name.contains('花'))

复制代码
students = Student.query.filter(and_(Student.s_age==16,
                                Student.s_name.contains('花')))

not_

students = Student.query.filter(or_(Student.s_age16,
Student.s_name.contains('花')))
or_
students = Student.query.filter(not_(Student.s_age16),

Student.s_name.contains('花'))

注意:

  1. fliter和filter_by的结果可遍历

  2. 可以通过对其结果使用all()方法将其转换成一个列表或者first()转换成objects对象。

  3. all()获得的是列表,列表没有first()方法

  4. fliter和filter_by有flrst()方法,没有last方法

    数据的添加

    在flask中修改数据后需要添加事务和提交事务

事务: 完整,一致,持久,原子

第一种:保存数据

将数据放入缓存

db.session.add(stu)

将缓存中的数据提交

db.session.commit()

复制代码
在学生表中添加数据

@blue.route('/createstu/')

def create_stu():

s = Student()

s.s_name = '小花'

s.s_age = 19

复制代码
db.session.add(s)
db.session.commit()

return '添加成功'

提交事务,使用commit提交我们的添加数据的操作

复制代码
批量创建数据

批量添加数据时可以使用add()、add_list()添加事务

add():

db.session.add_all(stu)

db.session.commit()

stu是一个对象

add_list():

db.session.add_all(stus_list)

db.session.commit()

stus_list是一个列表,其每个元素都是一个对象

复制代码
第一种

@app_blue.route('create_many_stu/',methods=['GET'])

def create_many_stu():

if request.method == 'GET':

stu = Student()

stus_list = []

for i in range(5):

stu = Student()

stu.s_name = '小花%s' % random.randrange(10, 1000)

stu.s_age = random.randint(10,20)

stus_list.append(stu)

复制代码
db.session.add_all(stus_list)
db.session.commit()
    # db.session.add(stu)
# db.session.commit
return '批量创建'

db.session.add_all(stus_list)

db.session.commit()

将列表中的数据统一添加到缓存区中,并提交

复制代码
第二种

第二种:重写init

models中:

def init (self, name, age):

2,给对象赋值

self.s_name = name

self.s_age = age

views中:

@app_blue.route('create_many_stu_init/',methods=['GET'])

def create_many_stu():

if request.method == 'GET':

stus_list = []

for i in range(5):

stu = Student('小花%s' % random.randrange(10,1000), random.randint(10,20))

stus_list.append(stu)

复制代码
    db.session.add_all(stus_list)
    db.session.commit()

        # db.session.add(stu)
    # db.session.commit
    return '批量创建成功'


修改数据

思路:获取到需要修改的对象,通过对象.属性的方式将属性重新赋值,然后使用commit提交事务

复制代码
写法1

students = Student.query.filter_by(s_id=3).first()

students.s_name = '哈哈'

db.session.commit()

复制代码
写法2

Student.query.filter_by(s_id=3).update({'s_name':'娃哈哈'})

db.session.commit()

复制代码
删除数据

格式:db.session.delete(对象)

db.session.commit()

注意:在修改数据(增删改)中如果使用commit()的话,只会修改本地缓存中的数据,数据库中的数据不会更新。

必须使用:db.session.commit()

复制代码
写法1

students = Student.query.filter_by(s_id=2).first()

db.session.delete(students)

db.session.commit()

复制代码
写法2

students = Student.query.filter_by(s_id=1).all()

db.session.delete(students[0])

db.session.commit()

复制代码

模型

相关推荐
惜分飞8 分钟前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean8 分钟前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_5500246311 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦12 分钟前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_999926 分钟前
Redis-2-queryFormat()方法
数据库·redis·缓存
B站_计算机毕业设计之家43 分钟前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
玄同7651 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码1 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean1 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
小Tomkk2 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase