SQLALchemy介绍:
具体详情:flask连接数据库
sqlalchemy是数据库的orm框架,让我们操作数据库的时候不要再用sql语句了,跟直接操作模型一样。
请求钩子:
- 在请求开始时,建立数据库连接;
- 在请求开始时,根据需求进行权限校验;
- 在请求结束时,指定数据的交互格式;
@app.before_first_request
#只有第一次请求之前调用,可以在此方法内部做一些初始化操作
@app.before_request
#每次请求之前都会触发
#在每一次请求之前调用,这时候已经有请求了,可能在这个方法里面做请求的校验
#如果请求的校验不成功,可以直接在此方法中进行响应,直接return之后那么就不会执行视图函数
@app.after_request
#在每次执行完视图函数之后会调用,要传入函数响应
#在执行完视图函数之后会调用,并且会把视图函数所生成的响应传入,可以在此方法中对应响应做最后一步统一的处理
@app.teardown_request
#每一次请求之后都会调用,会接受一个参数,参数是服务器出现的错误信息
sqlalchemy与Flask-sqlalchemy的区别:
sqlalchemy:是一个独立的ORM框架,可以独立于Flask存在,也可以在其他项目中使用,比如Django中。
Flask-sqlalchemy:对sqlalchemy的一个封装,能够更适合在flask中使用。
一、安装
1、安装连接数据库的库:pip install pymysql
2、安装: pip install flask-sqlalchemy
二、连接数据库:
基本的配置:
1: 首先先安装两个依赖的包。
2:配置数据库的连接:app.config[‘SQLALCHEMY_DATABASE_URI’] = “mysql://root:[email protected]:3306/test39”
3:关闭数据库的跟踪:app.config[‘SQLALCHEMY_TRACK_MODIFICATIONS’] = False
4:开启输出sql语句:app.config[‘SQLALCHEMY_ECHO’] = True
5:两种处理python2和python3的名字不一致问题。
from flask import Flask
from flask_restful import Api, Resource
from flask_sqlalchemy import SQLAlchemy
#import pymysql
#pymysql.install_as_MySQLdb()
"""
python2中数据库客户端: MySqldb
python3中数据库客户端:pymysql
解决方案一:让python2和python3的包进行转换。
import pymysql
pymysql.install_as_MySQLdb()
方案二:表示只使用python3的包,不使用python2的包
app.config['SQLALCHEMY_DATABASE_URI'] = "mysql+pymysql://root:[email protected]:3306/test39"
"""
app = Flask(__name__)
db = SQLAlchemy(app) #创建一个对象,设置名为db
# app.config['SQLALCHEMY_DATABASE_URI'] = "mysql://账号:密码@数据库ip地址:端口号/数据库名"
app.config['SQLALCHEMY_DATABASE_URI'] = "mysql+pymysql://root:[email protected]:3306/test39"
# app.config['SQLALCHEMY_BINDS'] = {}
# 关闭数据库修改跟踪操作[提高性能],可以设置为True,这样可以跟踪操作:
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
# 开启输出底层执行的sql语句
app.config['SQLALCHEMY_ECHO'] = True
# 开启数据库的自动提交功能[一般不使用]
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True
@app.route('/')
def hello_word():
return "hello, word"
if __name__ == '__main__':
print(app.url_map)
app.run(host='0.0.0.0', port= 8000, debug=True)
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
app = Flask(