Flask-SQLAlchemy 使用起来非常有趣,对于基本应用十分容易使用,并且对于大型项目易于扩展。

官方文档:https://flask-sqlalchemy.palletsprojects.com/en/2.x/

中文文档:http://www.pythondoc.com/flask-sqlalchemy/

安装

  1. pip install flask-sqlalchemy

配置

配置选项 说明
SQLALCHEMY_DATABASE_URI 连接数据库。示例:mysql://username:password@host/post/db?charset=utf-8
SQLALCHEMY_BINDS 一个将会绑定多种数据库的字典。 更多详细信息请看官文 绑定多种数据库.
SQLALCHEMY_ECHO 调试设置为true
SQLALCHEMY_POOL_SIZE 数据库池的大小,默认值为5。
SQLALCHEMY_POOL_TIMEOUT 连接超时时间
SQLALCHEMY_POOL_RECYCLE 自动回收连接的秒数。
SQLALCHEMY_MAX_OVERFLOW 控制在连接池达到最大值后可以创建的连接数。当这些额外的连接回收到连接池后将会被断开和抛弃。
SQLALCHEMY_TRACK_MODIFICATIONS 如果设置成 True (默认情况),Flask-SQLAlchemy 将会追踪对象的修改并且发送信号。这需要额外的内存, 如果不必要的可以禁用它。

创建及查询

  1. from flask import Flask
  2. from flask_sqlalchemy import SQLAlchemy
  3. app = Flask(__name__)
  4. app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
  5. db = SQLAlchemy(app)
  6. class User(db.Model):
  7. id = db.Column(db.Integer, primary_key=True)
  8. username = db.Column(db.String(80), unique=True)
  9. email = db.Column(db.String(120), unique=True)
  10. def __init__(self, username, email):
  11. self.username = username
  12. self.email = email
  13. def __repr__(self):
  14. return '<User %r>' % self.username
  15. if __name__ == '__main__':
  16. # 创建初始数据
  17. db.create_all()
  18. # 创建一些用户
  19. admin = User('admin', 'admin@example.com')
  20. guest = User('guest', 'guest@example.com')
  21. # 写入到数据库
  22. db.session.add(admin)
  23. db.session.add(guest)
  24. db.session.commit()
  25. # 访问数据库
  26. users = User.query.all()
  27. admin = User.query.filter_by(username='admin').first()
  28. print(users)
  29. print(admin)

结果:

  1. [<User 'admin'>, <User 'guest'>]
  2. <User 'admin'>

表关联

SQLAlchemy 连接到关系型数据库,关系型数据最擅长的东西就是关联。因此,我们将创建一个使用两张相互关联的表的应用作为例子:

  1. from flask import Flask
  2. from flask_sqlalchemy import SQLAlchemy
  3. from datetime import datetime
  4. app = Flask(__name__)
  5. app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
  6. db = SQLAlchemy(app)
  7. class Post(db.Model):
  8. id = db.Column(db.Integer, primary_key=True)
  9. title = db.Column(db.String(80), nullable=False)
  10. body = db.Column(db.Text, nullable=False)
  11. pub_date = db.Column(db.DateTime, nullable=False,
  12. default=datetime.utcnow)
  13. category_id = db.Column(db.Integer, db.ForeignKey('category.id'), # 外键
  14. nullable=False)
  15. # 与生成表结构无关,仅用于查询方便
  16. # backref 标示可通过relationship反向查找,Category.posts查询Post表数据
  17. category = db.relationship('Category',
  18. backref=db.backref('posts', lazy=True))
  19. def __repr__(self):
  20. return '<Post %r>' % self.title
  21. class Category(db.Model):
  22. id = db.Column(db.Integer, primary_key=True)
  23. name = db.Column(db.String(50), nullable=False)
  24. def __repr__(self):
  25. return '<Category %r>' % self.name
  26. if __name__ == '__main__':
  27. # 创建一些对象
  28. py = Category(name='Python')
  29. Post(title='Hello Python!', body='Python is pretty cool', category=py)
  30. p = Post(title='Snakes', body='Ssssssss')
  31. py.posts.append(p)
  32. db.session.add(py)
  33. # 现在因为我们在 backref 中声明了 posts 作为动态关系,查询显示为:
  34. print(py.posts)

运行结果:

  1. [<Post 'Hello Python!'>, <Post 'Snakes'>]

更多数据库的增删改查等功能参考官方文档:https://flask-sqlalchemy.palletsprojects.com/en/2.x/queries/

Flask-SQLAlchemy使用的更多相关文章

  1. flask SQLAlchemy中一对多的关系实现

    SQLAlchemy是Python中比较优秀的orm框架,在SQLAlchemy中定义了多种数据库表的对应关系, 其中一对多是一种比较常见的关系.利用flask sqlalchemy实现一对多的关系如 ...

  2. flask, SQLAlchemy, sqlite3 实现 RESTful API 的 todo list, 同时支持form操作

    flask, SQLAlchemy, sqlite3 实现 RESTful API, 同时支持form操作. 前端与后台的交互都采用json数据格式,原生javascript实现的ajax.其技术要点 ...

  3. flask建表遇到的错误: flask,sqlalchemy.exc.OperationalError: (MySQLdb._exceptions.OperationalError) (1071, 'Specified key was too long; max key length is 767 bytes')

    error:flask,sqlalchemy.exc.OperationalError: (MySQLdb._exceptions.OperationalError) (1071, 'Specifie ...

  4. Flask – SQLAlchemy成员增加

    目录 简介 结构 展示 技术 运行 代码 创建数据库表单 views视图 home主页 添加成员addnew.html 展示页show_all 简介 结构 $ tree -I "__pyca ...

  5. Flask+SQLAlchemy+alembic+Flask-RESTful使用

    前言 其实准备把这篇删掉,先写Flask-restful相关的,后来想想大体框架还是先写出来,这两天踩了很多坑,有的谷歌也没有答案.一直摸索也总算是开始了. 正文 SQLAlchemy/alembic ...

  6. flask SQLALchemy外键及约束

    from flask import Flask,session from flask_sqlalchemy import SQLAlchemy import config app = Flask(__ ...

  7. python3 + flask + sqlalchemy +orm(3):多对多关系

    一篇文章有多个tag,一个tag也可以属于多篇文章,文章和tag存在多对多关系 config.py DEBUG = True #dialect+driver://root:1q2w3e4r5t@127 ...

  8. python3 + flask + sqlalchemy +orm(2):数据库中添加表

    往数据库中添加一张保存文章的表,表明为article,字段有id,title,content 同样一个配置文件:config.py DEBUG = True #dialect+driver://roo ...

  9. python3 + flask + sqlalchemy +orm(1):链接mysql 数据库

    1.pycharm中新建一个flask项目 2.按装flask.PyMySQL.flask-sqlalchemy 3.项目下面新建一个config.py 文件 DEBUG = True #dialec ...

  10. Flask SQLAlchemy & model

    Flask-SQLAlchemy Flask-SQLAlchemy库让flask更方便的使用SQLALchemy,是一个强大的关系形数据库框架,既可以使用orm方式操作数据库,也可以使用原始的SQL命 ...

随机推荐

  1. poj3661 Running

    Description The cows are trying to become better athletes, so Bessie is running on a track for exact ...

  2. 【POJ 1148】Utopia Divided

    Utopia Divided 题目链接:POJ 1148 题目大意 在一个坐标系中,一个点一开始在原点,然后被要求每次走到一个规定的象限内. 你有一些互不相同的数,每次你可以选每选过的两个,正负性可以 ...

  3. Java魔法堂:调用外部程序

    前言 Java虽然五脏俱全但总有软肋,譬如获取CPU等硬件信息,当然我们可以通过JNI调用C/C++来获取,但对于对C/C++和Windows API不熟的码农是一系列复杂的学习和踩坑过程.那能不能通 ...

  4. mysql-画图

    目录 阿里数据库产品rds 淘宝数据库架构 数据库下载 Mysql3种安装方法 mysql_install_db安装数据库命令脚本中有生成初始mysql数据 也可以把mysql_install_db集 ...

  5. Redis 搭建与配置

    Redis 简介 Redis 是一款开源的,ANSI C 语言编写的,高级键值(Key-Value)缓存和支持永久存储 NoSQL 数据库产品, Redis 采用内存(In-Memory)数据集(Da ...

  6. u-boot 移植 --->7、u-bootl流程粗线条梳理

    通过前面的调试了解到s5pv210这个芯片的启动流程是需要将u-boot分为两部分的分别为SPL和u-boot.这里我使用网上的方式不直接使用u-boot的SPL连接脚本单独生成SPL的image而是 ...

  7. Keras读取保存的模型时, 产生错误[ValueError: Unknown activation function:relu6]

    Solution: from keras.utils.generic_utils import CustomObjectScope with CustomObjectScope({'relu6': k ...

  8. H5 Funny Games All In One

    H5 Funny Games All In One H5 游戏 盖楼 游戏 https://iamkun.github.io/tower_game/ https://github.com/iamkun ...

  9. 在线打开,浏览PDF文件的各种方式及各种pdf插件------(MS OneDrive/google drive & google doc/ github ?raw=true)

    在线打开,浏览PDF文件的各种方式: 1 Google drive&doc   (国内不好使,you know GFW=Great Firewall) 1. google drive: 直接分 ...

  10. Nuxt.js SSR Optimizing Tips

    Nuxt.js SSR Optimizing Tips 性能优化 FP 首次绘制时间 FCP 首次渲染时间 FMP 首屏渲染时间 FI refs https://vueschool.io/articl ...