Python flask:数据库(Day 1)

Step 1:MySQL 安装

所用的系统为 Windows 10

社区版 MySQL installer 下载

进入 installer 下载界面,选择 Windows(x86, 32-bit), MSI Installer

下载完成后点击开始安装(详细配置自行选择,一般直接 next 就可以了)

可能会遇到提示,缺少 Microsoft Visual C++ 2019 Redistributable Package (x64) 这个文件

点此下载

安装完成后打开 MySQL 8.0 Command Line Client,输入安装过程中自定义的密码即可

Step 2:数据库驱动 PyMySQL

  • 如果使用 python2.x

安装 mysql-python 驱动,直接在虚拟环境下 pip 如果报错,则 点此下载

打开 cmd ,开启虚拟环境并切换至下载路径

输入: pip install MySQL_python-1.2.5-cp27-none-win_amd64.whl

这里操作系统为windows10 64位,若为32位则可下载 win32 的文件

  • 如果使用 python3.x

安装 PyMySQL 驱动,打开 cmd 并开启虚拟环境,直接 pip install PyMySQL

关于 mysql-pythonPyMySQL

mysql-python 不支持 flask 2.0python2.x 应当安装 mysql-pythonpython3.x 应当安装PyMySQL,在虚拟环境下输入 pip install PyMySQL 即可;若使用 mysql-python , 在配置文件下,数据库驱动 DRIVER = mysqldb ,若使用 PyMySQLDRIVER = pymysql

Step 3:添加库 flask-sqlalchemy

在虚拟环境下添加该库(依次输入以下语句)

pipenv shell
...

pip install flask-sqlalchemy
...

Step 4:服务器与 DB 连接(配置文件)

通过 demo01 -> new -> Python File 新建 config.py 作为配置文件

连接数据库的配置格式为 dialect+driver//username:password@host:port/database?charset=utf8

在配置文件中添加以下设置,分别填入格式中的 {}

# encoding = utf-8
DIALECT = 'mysql'       # 填入所用的数据库名称
DRIVER = 'pymysql'      # 数据库驱动
USERNAME = 'root'       # 用于登陆数据库的用户名,这里选用默认的 root
PASSWORD = 'root'       # 对应的密码
HOST = '127.0.0.1'      # 即 localhost,默认为 127.0.0.1
PORT = '3306'           # 安装数据库时选择的端口,默认为 3306
DATABASE = 'db_demo'    # 先建立一个名为 db_demo 的数据库

再使用以下语句来进行配置:

SQLALCHEMY_DATABASE_URI = "{}+{}//{}:{}@{}:{}/{}?charset=utf8".format(DIALECT, DRIVER, USERNAME, PASSWORD, HOST, PORT, DATABASE)

同时在 app.py 文件中导入 config.py 并与数据库进行连接:

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
import config

app = Flask(__name__)
app.config.from_object(config)
db = SQLAlchemy(app)

db.create_all()

Step 5:基本 CURD 操作的实现

MySQL 的基本操作:

  • 创建数据库:create database db_demo charset utf8;
  • 使用指定数据库:use db_demo;
  • 指定 DB 下列出所有表单:show tables;
  • 查找某一张表(假设为 test):select *from test

只要是通过 db.session 完成的操作,必须通过 db.session.commit() 来提交事务

1. create 增加

  • 创建类的实例,并将需要填入 DB 中的数据写入初始化操作当中
test1 = Test(title='first_title', content='first_content')
  • 确定事务为“添加“
db.session.add(test1)
  • 提交事务
db.session.commit()

2. retrieve 查询

  • 创建一个 query 对象,用于接收满足查找条件的数据
result = Test.query.filter(Test.title == 'first_title')
  • result 中索引为 1 的信息指定给 user1
user1 = result[0]
# 或者写为 user1 = result.first()
# 此时 user1 即指向了 test 表中 title 为 'first_title' 的所有行中的第一行

前两行可合成为一行代码:user1 = Test.query.filter(Test.title == 'first_title')

  • 将值传输给对应 html 文件或直接显示

3. update 更新

这两步操作都以 为前提

  • 接收对应行数据
user1 = Test.query.filter(Test.title == 'first_title').first()
  • 进行 操作
user1.content = 'new_content'
  • 这一事务上传至 MySQL DB
db.session.commit()

4. delete 删除

  • 接收对应行数据
user1 = Test.query.filter(Test.title == 'first_title').first()
  • 进行 删除 操作
db.session.delete(user1)
  • 这一事务上传至 MySQL DB
db.session.commit()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,470评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,393评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,577评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,176评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,189评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,155评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,041评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,903评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,319评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,539评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,703评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,417评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,013评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,664评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,818评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,711评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,601评论 2 353