零、什么是SQLAlchemy
SQLAlchemy是 Python 中常用的ORM框架
一、安装
在命令行中打开虚拟环境,在虚拟环境中输入如下命令:
pip install flask-sqlalchemy
二、设置连接字符串连接数据库
1.初始化sqlalchemy对象
from flask import Flaskfrom flask_sqlalchemy import SQLAlchemyapp = Flask(__name__)# 初始化sqlalchemy对象db = SQLAlchemy(app)@app.route('/')def index(): return 'index'if __name__ == '__main__': app.run(debug=True)
2.设置连接字符串
DIALECT = 'mysql' # 所连接的数据库累心DRIVER = 'mysqldb' # 数据库驱动名称USERNAME = 'root' # 数据库用户名PASSWORD = 'root' # 数据库密码HOST = '127.0.0.1' # 数据库地址PORT = '3306' # 数据库端口号
3.引入配置文件
from flask import Flaskfrom flask_sqlalchemy import SQLAlchemy# 引入configimport configapp = 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 Flaskfrom flask_sqlalchemy import SQLAlchemyimport configapp = Flask(__name__)app.config.from_object(config)db = SQLAlchemy(app)# 数据库模型必须继承db.Modelclass 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)