零、什么是SQLAlchemy
SQLAlchemy是 Python 中常用的ORM框架
一、安装
在命令行中打开虚拟环境,在虚拟环境中输入如下命令:
代码语言:javascript复制pip install flask-sqlalchemy
二、设置连接字符串连接数据库
1.初始化sqlalchemy对象
代码语言:javascript复制from flask import Flask
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
# 初始化sqlalchemy对象
db = SQLAlchemy(app)
@app.route('/')
def index():
return 'index'
if __name__ == '__main__':
app.run(debug=True)
2.设置连接字符串
代码语言:javascript复制DIALECT = 'mysql' # 所连接的数据库累心
DRIVER = 'mysqldb' # 数据库驱动名称
USERNAME = 'root' # 数据库用户名
PASSWORD = 'root' # 数据库密码
HOST = '127.0.0.1' # 数据库地址
PORT = '3306' # 数据库端口号
3.引入配置文件
代码语言:javascript复制from flask import Flask
from flask_sqlalchemy import SQLAlchemy
# 引入config
import config
app = Flask(__name__)
# 设置配置
app.config.from_object(config)
# 初始化sqlalchemy对象
db = SQLAlchemy(app)
#验证是否连接正确
db.create_all()
@app.route('/')
def index():
return 'index'
if __name__ == '__main__':
app.run(debug=True)
三、模型与表映射
- 数据库模型必须集成db.Model
- 如果表名称没有指定,将使用类名称的小写形式
- 表属性名称必须以开头,以结尾
- 只要是映射到数据库的字段,必须=db.Column()
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
import config
app = Flask(__name__)
app.config.from_object(config)
db = SQLAlchemy(app)
# 数据库模型必须继承db.Model
class Article(db.Model):
# 定义表名,如果不指定表名,将使用类名称的小写形式,
# 表名属性必须以__开头__结尾
__tablename__ = 'article'
# 只要是映射到数据库的字段,必须=db.Column()
# 参数解释
# db.Integer:数据类型,此处为整型
# primary_key:是否是主键,此处是主键
# autoincrement=True:是否自增长,此处是自增长
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
# db.String(100):最大长度为100的字符串类型
# nullable:是否可以为空
title = db.Column(db.String(100), nullable=False)
content = db.Column(db.Text, nullable=False)
# 映射表
db.create_all()
@app.route('/')
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
app.run(debug=True)