# 配置flask-sqlalchemy
说到flask-sqlalchemy,有些人可能不太清楚是什么东西。简单的说,他就是一个orm库,帮助咱们能够更好地跟db打交道的。笔者有一篇文章 (opens new window)有略微的介绍,可以速览一遍了解一下(其实主要是笔者才疏学浅,讲不出什么深奥的。
既然是登录,那么肯定需要有持久化的数据。那么我们肯定需要建立用户相关的表。
# 前置准备
安装MySQL
根据自己的系统(Windows/Mac/Linux)安装好对应的MySQL并设置好账号密码,这里就不教育大家怎么安装了。端口号用默认的3306即可,并且确保服务要启动成功哦!
安装mysql-connector-python(mysql官方驱动)
cmd窗口执行
pip3 install mysql-connector-python
# 配置MySQL连接信息
- pity/config.py配置mysql连接信息
注意: 一定要确保MySQL的库存在哦, 没有的话可以用Navicat或Datagrip新建。
可以看出以上包含了5个重点内容,mysql的地址,端口号,用户名,密码和库名。接下来的SQLALCHEMY_DATABASE_URI代表了sql的连接信息,flask_sqlalchemy会自动根据这个变量去获取db连接等。其中mysql+mysqlconnector
,代表的是试用mysql连接的方式,大家都知道Python连接mysql有很多库比如pymysql,mysqldb等。这里就是一个说明。
至于后面的警告大家可加可不加,如果被警告得太烦了可以这样解决。
SQLALCHEMY_DATABASE_URI = 'mysql+mysqlconnector://{}:{}@{}:{}/{}'.format(
MYSQL_USER, MYSQL_PWD, MYSQL_HOST, MYSQL_PORT, DBNAME)
2
- 在
pity/app/models/__init__.py
初始化db
代码很简单,就是将app赋给SQLAlchemy从而生成一个db对象。
from flask_sqlalchemy import SQLAlchemy
from app import pity
db = SQLAlchemy(pity)
2
3
4
5
# 配备用户类
- 在models目录建立用户表
首先咱们这个平台肯定不是那种不需要登录的,因为会做一小部分的权限控制,但是肯定也不会很复杂化。所以我们可以先简略设计一下用户表。
既然是Orm,那么咱们的User表的体现即是Python中的一个类。
因为目前,还不太了解用户表的具体需要字段。但是我们能大概设计一下这个表,首先需要的字段肯定有用户名,密码,用户id,邮箱,团队id,职位等。其他的信息比如enable(是否可用),create_time(创建时间)等信息暂时先不考虑了。后续可以随意添加。
那么User表我的大概设计如下:
大致讲一下吧,大概就创建了以上几个字段。unique是字段是否唯一(可重复),primary key自然就是主键,db.String对应varchar,db.INT对应int,也就是说。现在我们要操作数据表,只需要对这个User类操作就行了,因为sqlalchemy会自动映射到对应库--对应表进行操作。
from app.models import db
from datetime import datetime
class User(db.Model):
id = db.Column(db.INT, primary_key=True)
username = db.Column(db.String(16), unique=True, index=True)
name = db.Column(db.String(16), index=True)
password = db.Column(db.String(32), unique=False)
email = db.Column(db.String(64), unique=True, nullable=False)
role = db.Column(db.INT, default=0, comment="0: 普通用户 1: 组长 2: 超级管理员")
created_at = db.Column(db.DATETIME, nullable=False)
updated_at = db.Column(db.DATETIME, nullable=False)
deleted_at = db.Column(db.DATETIME)
last_login_at = db.Column(db.DATETIME)
def __init__(self, username, name, password, email):
self.username = username
self.password = password
self.email = email
self.name = name
self.created_at = datetime.now()
self.updated_at = datetime.now()
self.role = 0
def __repr__(self):
return '<User %r>' % self.username
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
- 在引入models的地方初始化数据表
我们在pity/dao/__init__.py
dao层初始化所有表,以后新增一个表都需要在这儿import一次
from app.models import db
from app.models.user import User
db.create_all()
2
3
4
- 在run.py引入dao包使得建表语句db.create_all()生效
重启服务后可以看到出现了user表:
# 广告时间
后端代码地址: https://github.com/wuranxu/pity (opens new window)
前端代码地址: https://github.com/wuranxu/pityWeb (opens new window)
欢迎关注公众号测试开发入坑,还有加群一起讨论相关问题呀!如果群二维码过期了,可以加我个人微信: wuranxu
我拉你进群~