1、安装flask_sqlalchemy和pymysql包
pip install flask-sqlalchemy
pip install pymysql
2、进行配置
使用Flask-SQLAlchemy扩展操作数据库,首先需要通过URL建立数据库连接,必须保存到Flask配置对象的SQLALCHEMY_DATABASE_URI中。
- HOSTNAME = '127.0.0.1'
- PORT = '3306'
- DATABASE = 'flask_test'
- USERNAME = 'root'
- PASSWORD = 'root'
- DB_URI = 'mysql+pymysql://{}:{}@{}:{}/{}?charset=utf8'.format(USERNAME,PASSWORD,HOSTNAME,PORT,DATABASE)
- app.config['SQLALCHEMY_DATABASE_URI'] = DB_URI
其中HOSTNAME为路由地址
PORT为端口号,我在创建数据库时没有更改,所以用的默认的3306端口号
DATABASE为数据库名字
后面两个参数为数据库用户名和密码
3、创建SQLALchemy实例
db = SQLAlchemy(app)
我这里创建的实例记为db
4、创建ORM类
创建这个类必须继承db.Model !!!
- class Article(db.Model):
- __tablename__ = "article"
- id = db.Column(db.Integer, primary_key=True, autoincrement=True)
- title = db.Column(db.String(200), nullable=False)
- content = db.Column(db.Text, nullable=False)
第二行设置数据库表名为article。第三行设置id项,将其设置为整数项,并且设置为主键以及自动增长。第四行设置title项,将其设置为含200个字符的字符串,并设置不能非空。第五行设置content项,将其设置为db.Text格式并且设置不能非空。
5、创建表
db.create_all()
然后就会发现,数据库中多出一张表:
当然,这张表目前还是空的
6、在表中增删查改数据
我们可以在一个视图函数中执行这些操作,当然也可以直接执行
- @app.route("/article")
- def article_view():
- # 添加数据
- article = Article(title="钢铁是怎样炼成的", content="xxx")
- db.session.add(article)
- db.session.commit()
-
- # # 查询数据
- # article = Article.query.filter_by(id=1)[0]
- # print(article.title)
- #
- # # 修改数据
- # article = Article.query.filter_by(id=1)[0]
- # article.content = "yyy"
- # db.session.commit()
- #
- # # 删除数据
- # article = Article.query.filter_by(id=1)[0]
- # db.session.delete(article)
- # db.session.commit()
- return "数据操作成功"
添加数据时没加id,是因为我们之前设置id的autoincrement为True,于是它会自动增加。
执行完发现数据库中多出了如下:
其他三步结果请自行查看。当然,如果想观察每一步的结果,在执行添加数据前最好最好先将其他三步加上注释,对于其他三步也是一样。