python Flask 操作数据库(2)
单表操作
数据准备
from flask import Flask
from flask_sqlalchemy import SQLAlchemy class Config:
DEBUG = True
SQLALCHEMY_DATABASE_URI = "mysql://root:123456@127.0.0.1:3306/demo"
SQLALCHEMY_TRACK_MODIFICATIONS = False app = Flask(__name__)
app.config.from_object(Config)
db = SQLAlchemy(app) # 模型类 -》对一个表设计
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(64))
age = db.Column(db.Integer) @app.route("/", methods=["GET", "POST"])
def index():
return "成功!"
if __name__ == '__main__':
db.create_all()
app.run()
添加记录
user = User(name="laowang", age=18)
db.session.add(user) # 逻辑添加
db.session.commit()
删除记录
# res = User.query.filter_by(name="laowang").first()
# db.session.delete(res)
# db.session.commit()
修改记录
res = User.query.filter_by(id=3).first()
res.name="老色批"
db.session.commit()
查询记录
SQLAlchemy中关于查询分为两部分:一个是查询过滤器,一个是查询执行器。
常用的SQLAlchemy查询过滤器
| 过滤器 | 说明 | 
|---|---|
| filter() | 把过滤器添加到原查询上,返回一个新查询 | 
| filter_by() | 把等值过滤器添加到原查询上,返回一个新查询 | 
| limit | 使用指定的值限定原查询返回的结果 | 
| offset() | 偏移原查询返回的结果,返回一个新查询 | 
| order_by() | 根据指定条件对原查询结果进行排序,返回一个新查询 | 
| group_by() | 根据指定条件对原查询结果进行分组,返回一个新查询 | 
常用的SQLAlchemy查询执行器
| 方法 | 说明 | 
|---|---|
| all() | 以列表形式返回查询的所有结果 | 
| first() | 返回查询的第一个结果,如果未查到,返回None | 
| first_or_404() | 返回查询的第一个结果,如果未查到,返回404 | 
| get() | 返回指定主键对应的行,如不存在,返回None | 
| get_or_404() | 返回指定主键对应的行,如不存在,返回404 | 
| count() | 返回查询结果的数量 | 
| paginate() | 返回一个Paginate对象,它包含指定范围内的结果 | 
演示
@app.route("/select_book")
def select_book():
    # 1.查询所有用户数据
    # res = Books.query.all()
    # 说明:因为这里不想条件筛选,所以不需要查询过滤器
    #
    # # 2.查询有多少个用户
    # res = Books.query.count()
    # 3.查询第1个用户
    res = Books.query.first()
    # # # 4.查询id为4的用户[3种方式]
    # res = Books.query.get(1)      # 使用这种方式,后面只需要填写id值
    # res = Books.query.filter_by(id=4).first()
    res = Books.query.filter(Books.id == 1).first()
    """
    filter_by和filter的区别
    格式:
        filter_by:  属性=
        filter:  对象.属性==
    功能:
    filter功能上更加强大,可以实现更多的查询方式,比如比较运算符
    """
    print(res)
    return "查询成功"
一对多表操作
代码准备:
from flask import Flask
from flask_sqlalchemy import SQLAlchemy class Config:
DEBUG = True
SQLALCHEMY_DATABASE_URI = "mysql://root:123456@127.0.0.1:3306/demo"
SQLALCHEMY_TRACK_MODIFICATIONS = False app = Flask(__name__)
app.config.from_object(Config)
db = SQLAlchemy(app) class Publishers(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(64))
address = db.Column(db.String(64)) def _str_(self): # print显示内容做设置
return self.name def _repr__(self): # 对列表中显示内容做设置
return self.name class Book(db.Model):
id = db.Column(db.Integer,primary_key=True)
title = db.Column(db.String(64))
price =db.Column(db.Integer)
pub_id = db.Column(db.Integer,
db.ForeignKey("publishers.id")
)
def _str_(self): # print显示内容做设置
return self.title def _repr__(self): # 对列表中显示内容做设置
return self.title
@app.route('/',methods=["GET","POST"])
def hello_world():
return "成功"
if __name__ == '__main__':
db.create_all()
app.run()
添加数据
books=Book(id=1,title="养鬼为祸",price=50,pub_id=1)
db.session.add(books) # 逻辑添加
db.session.commit()
删除数据
es = Book.query.filter(Book.id == 1).first()
db.session.delete(es)
db.session.commit()
修改数据
es =Book.query.filter_by(id=1).first()
es.title="西游记"
db.session.commit()
查找数据
es =Publishers.query.filter(Publishers.name == "南方出版社").first()
ls = Book.query.filter(Book.pub_id == es.id).all()
print(ls)
没毛病!
python Flask 操作数据库(2)的更多相关文章
- Python——Flask框架——数据库
		一.数据库框架 Flask-SQLAlchemy (1)安装: pip install flask-sqlalchemy (2)Flask-SQLAlchemy数据库URL 数据库引擎 URL MyS ... 
- flask 操作数据库(分类)
		数据库 数据库是大多数动态web程序的基础设施,只要你想把数据存下来,就离不开数据库. 这里所说的数据库指的是有存储数据的单个或多个文件组成的集合,它是一种容器,可以类比文文件柜.而人们通常使用数据库 ... 
- MySQL---连接器(python如何操作数据库媒介,基于python语言)
		MySQL — 连接器 连接器的概念 它们往往是一类Python包,或者是一类已经写好的Python库.这些库提供了我们Python去连接数据库服务器的基本功能.  既然它是一个包,那么我们首先学会 ... 
- Python:操作数据库
		(一) 前言 本文说明如何连接Oracle.MySQL.sqlserver,以及执行sql.获取查询结果等. (二) DB-API DB-API阐明一系列所需对象和数据库 ... 
- Python连接操作数据库
		步骤: 1.创建与数据库的连接对象: 2.创建游标: 3.通过游标执行语句 4.增删改需要提交(commit)数据 5.关闭连接 如: import MySQLdb # Python通过MySQL ... 
- python中操作数据库
		python中要操作数据库,要使用该数据库在python中对应的驱动库,本文介绍python操作mysql数据库 1.首先安装pymysql 2.导入库 3.建立连接 4.建立游标 5.发起请求 6. ... 
- python 连接操作数据库(二)
		一.我们接着上期的博客继续对ORM框架进行补充,顺便把paramiko模块也给大家讲解一下: 1.ORM框架: 在连接操作数据库的第一个博客中也已经说了,sqlalchemy是一个ORM框架,总结就是 ... 
- python 多线程操作数据库
		如果使用多线程操作数据库,容易引起多用户操作锁表 OperationalError: (2013, 'Lost connection to MySQL server during query') 使用 ... 
- python 连接操作数据库(一)
		一.下面我们所说的就是连接mysql的应用: 1.其实在python中连接操作mysql的模块有多个,在这里我只给大家演示pymysql这一个模块(其实我是感觉它比较好用而已): pymysql是第三 ... 
- python redis操作数据库方法
		Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ... 
随机推荐
- NSIS 检测默认浏览器
			#检测默认浏览器 #编写:水晶石 #原理:用FindExecutable函数查找htm关联程序路径与名称,然后分析字串中包含的可执行文件名. !include "LogicLib.nsh&q ... 
- Spring让人眼前一亮的11个小技巧
			前言 我们一说到spring,可能第一个想到的是 IOC(控制反转) 和 AOP(面向切面编程). 没错,它们是spring的基石,得益于它们的优秀设计,使得spring能够从众多优秀框架中脱颖而出. ... 
- HDU4991 Ordered Subsequence (树状数组优化DP)
			dp[i][j]表示以a[i]结尾的长度为j的上升子序列个数. 方程:dp[i][j]=sum(dp[k][j-1]),a[k]<a[i],1<=k<i. 求解目标:sum(dp[k ... 
- Vue中组件化编码使用、实现组件之间的参数传递(实战练习二)
			上一章节实现的是静态页面的设计.这一章节实现将数据抽取出来.通过组件间参数的传递来实现 上一章节链接地址:https://blog.csdn.net/weixin_43304253/article/d ... 
- 中国制霸生成器「GitHub 热点速览 v.22.42」
			火遍推特的中国制霸生成器本周一开源就占据了两天的 GitHub Trending 榜,不知道你的足迹遍布了多少个省份呢?同样记录痕迹的 kanal 用了内存读写方式解决了 Rust 的消息处理问题,P ... 
- C语言客房管理&酒店管理
			#include<iostream> #include<string.h> #include<stdlib.h> #include<iomanip> # ... 
- LVS综合实验
			LVS综合实验 1.环境准备 提前准备:Mysql8.0.30安装包.Mysql安装脚本.shopxo2.3.0安装包.DNS脚本 服务器 IP地址 作用 系统版本 Mysql-master 10.0 ... 
- 词云(WordCloud)
			WordCloud的参数: font_path:可用于指定字体路径 width:词云的宽度,默认为 400: height:词云的⾼度,默认为 200: mask:蒙版,可⽤于定制词云的形状: min ... 
- 使用VsCode调试UE5的PuerTs
			使用VsCode调试UE5的PuerTs 1.下载测试的Demo项目 配置PuerTs的步骤这里不赘述. 2.准备工作 2.1 打开项目 正常来说,直接打开项目可以看到如下画面 如果直接点击运行,可以 ... 
- 野火 STM32MP157 开发板内核和设备树的编译烧写
			一.环境 编译环境:Ubuntu 版本:18.4.6 交叉编译工具:arm-linux-gnueabihf-gcc 版本:7.4.1 开发板:STM32MP157 pro 烧写方式:STM32Cube ... 
