Flask:初次使用Flask-SQLAlchemy读取SQLite3
Windows 10家庭中文版,Python 3.6.4,Flask 1.0.2,Eclipse Oxygen.1a Release (4.7.1a),PyDev 6.3.2
SQLAlchemy是一个Python的SQL工具包和对象关系映射工具,它给应用开发者提供了全部且灵活的SQL操作(数据库支持)。
Flask-SQLAlchemy是用于支持SQLAlchemy的Flask插件(怎么开发的?Flask文档有讲解,当然,还得了解SQLAlchemy)。
安装Flask-SQLAlchemy:
pip3 install Flask-SQLAlchemy
会同时把没安装的SQLAlchemy安装上。
参考链接:Flask官网的SQLAlchemy in Flask(后称【官文】)
本文的测试是基于参考链接进行的,测试了其中介绍的三种使用Flask-SQLAlchemy的方式:
1.Declarative
重点:
使用declarative_base()函数建立了Base类,要在数据库中建立自己的表,继承Base类 并 在类中使用Column定义字段即可;
使用scoped_session、sessionmaker建立了与数据库的session——db_session,可以当作是一个连接,开发者可以通过其下的函数操作数据库中的数据。
2.手动ORM
重点:
相比于Declarative方式,此方式不需要建立Base之类的类,但是要使用sqlalchemy下的MetaData()函数建元数据对象(metadata或其它变量名);
相比于Declarative方式,其类和字段定义不是写在一起的,而是分开写,再使用sqlalchemy.orm下的mapper()函数对两者进行映射,这显得更灵活,但要写更多代码;
注意,在【官文】中,手动ORM 下的init_db()函数下面还缺少下面一句——导入models.py,否则,无法自动建表:
import yourapplication.models
3.使用SQL抽象层
重点:
这种方式给开发者提供了“更深入”的操作数据库的能力;
但是,需要自己建立数据库连接 并 在使用完毕后及时清理,没法让Flask自动完成(可以吗?请给点提示);
建立数据表的方式和方式1、2相同,也可以选择从数据库中自动加载(Table函数中autoload=True);
使用数据库引擎获取连接对象,然后,可以使用其execute函数执行很多功能,参考连接;
Table对象在【官文】中主要提供了查询功能,或许有其它功能,需要看SQLAlchemy官网。
测试说明:
使用命令行进入src目录进行的,因此,如果是其它目录,需要更改代码中的数据库文件地址。
测试项目sqlalchemy001结构:
其中,database1.py、models.py、sqlite1.db用于方式1的测试,其它**2文件用于方式2测试、**3文件用于方式3的测试。
测试期间发生的错误:
1.将models.py文件中User类的__repr__的名字写错了,属于“一个字符错误”
原因:正确的是以两个下划线开头,而自己写了一个。
错误现象:
测试是返回的结果和预期不一致,看不到直观的表记录内容,如下:
<sqlalchemy.orm.query.Query object at 0x000002328F434470>
期望结果 和 【官文】一致,更正函数名称后即可。
2.数据库的地址错了!无法打开数据库文件!
原因:我在命令行中进行测试,进入的是sqlalchemy001目录的上一级src目录,在这里导入了模块,但是,用os.getcwd()获取的是src的路径,而不是sqlalchemy001包的路径,因此,数据库的相对地址就是有问题的了。如果这些模块是在Flask应用中使用的话,我的database.py中的相对地址就是正确的。这个相对,并不是和模块文件所在位置相对,而是和模块导入的位置相对。
解决:使用命令行进入src目录进行测试,这样可以确保发布代码时不需要更改路径。
补充:需要学习SQLAlchemy怎么连接数据库的,比如这里就遇到了SQLite访问时设置相对、绝对、内存地址的问题,参考官方文档。不过,我的数据库连接地址和官网中不一样,但我的也是可用的,或许SQLAlchemy已经做了更新,已运行代码为准。
说明:源码中src目录下的cmd_tests.txt是测试期间执行的所有命令。
后记
感觉今天就联系了怎么使用Flask-SQLAlchemy,而没有将它强大的功能真正应用到Flask项目中,还需要更多测试才行,连接其它数据库、构建一个使用数据库的系统;
那么,使用它就可以让Flask项目连接更多种类的数据库吧?
SQLAlchemy的功能很强大,今天只是接触了皮毛,想精通,需要花费的时间应该不少于学习Flask吧!把握大要,遇到再快速学习就好啦!
Flask:初次使用Flask-SQLAlchemy读取SQLite3的更多相关文章
- python 全栈开发,Day142(flask标准目录结构, flask使用SQLAlchemy,flask离线脚本,flask多app应用,flask-script,flask-migrate,pipreqs)
昨日内容回顾 1. 简述flask上下文管理 - threading.local - 偏函数 - 栈 2. 原生SQL和ORM有什么优缺点? 开发效率: ORM > 原生SQL 执行效率: 原生 ...
- flask插件系列之SQLAlchemy基础使用
sqlalchemy是一个操作关系型数据库的ORM工具.下面研究一下单独使用和其在flask框架中的使用方法. 直接使用sqlalchemy操作数据库 安装sqlalchemy pip install ...
- flask系列四之SQLAlchemy
一.SQLAlchemy简介 (1)flask_sqlalchemy是一套ORM框架. (2)ORM(Object Relationship Mapping):模型关系映射 (3)ORM的好处:可以让 ...
- flask的orm框架(SQLAlchemy)-操作数据
# 原创,转载请留言联系 Flask-SQLAlchemy 实现增加数据 用 sqlalchemy 添加数据时,一定要注意,不仅仅要连接到数据表,并且你的创建表的类也必须写进来.而且字段和约束条件要吻 ...
- flask的orm框架(SQLAlchemy)-创建表
# 转载请留言联系 ORM 是什么? ORM,Object-Relation Mapping.意思就是对象-关系映射.ORM 主要实现模型对象到关系数据库数据的映射. 优点 : 只需要面向对象编程, ...
- Flask01 初识flask、创建flask应用、flask启动配置
1 什么是flask Flask是一个使用 Python 编写的轻量级 Web 应用框架.其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2 . 百度百科:点击前往 中文文档: ...
- flask第一章 flask启动 路由视图 FlaskRequest jinja2 FlaskSession
一.简单了解flask web框架 优点: 小而精,组件只有session,第三方机构强烈支持flask,极其简单 缺点: 由于第三方软件的关系,稳定性相对较差,flask-session 扩展知识: ...
- Flask最强攻略 - 跟DragonFire学Flask - 第九篇 Flask 中的蓝图(BluePrint)
蓝图,听起来就是一个很宏伟的东西 在Flask中的蓝图 blueprint 也是非常宏伟的 它的作用就是将 功能 与 主服务 分开怎么理解呢? 比如说,你有一个客户管理系统,最开始的时候,只有一个查看 ...
- Flask系列(二)Flask基础
知识点回顾 1.flask依赖wsgi,实现wsgi的模块:wsgiref(django),werkzeug(flask),uwsgi(上线) 2.实例化Flask对象,里面是有参数的 app = F ...
随机推荐
- 【poj3294】 Life Forms
http://poj.org/problem?id=3294 (题目链接) 题意 给定 n 个字符串,求出现在不小于 k 个字符串中的最长子串. Solution 后缀数组论文题.. 将 n 个字符串 ...
- Android Intent 总结
//打开指定网页Intent intent = new Intent(Intent.ACTION_VIEW);intent.setData(Uri.parse("http://www.goo ...
- LigerUI下拉选择列表LigerComboBox中tree的节点初始化默认选中的问题
问题描述 用后台的Json传送tree的数据 前端用js方法来控制选中节点 此方法存在bug 实例: bug问题:无论设置的默认选中值是多少个,前台checkbox最多只显示选中一个,但是内容框中显示 ...
- unity还原three——顶点,三角面,uv
public class Geometry { public Geometry(string name, Data data, Hashtable hash) { Debug.Log("解析 ...
- NATS_10:NATS服务配置文件详解
尽管NATS可以无配置的运行,但也可以使用配置文件配置NATS服务的启动,在实际应用当中,一般都是通过使用配置文件来启动服务的. 1. 配置项包括 客户端监听器端口 Client listening ...
- gitlab的备份与恢复与迁移
一.gitlab的备份1.1 创建备份目录,并授权 1 2 3 4 [root@linux-node1 ~]# mkdir /data/backups/gitlab -p [root@linux-no ...
- 51 nod 1105 第K大的数
1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 收藏 关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...
- hive架构原理简析-mapreduce部分
整个处理流程包括主要包括,语法解析(抽象语法树,AST,采用antlr),语义分析(sematic Analyzer生成查询块),逻辑计划生成(OP tree),逻辑计划优化,物理计划生成(Task ...
- python3 flask部署新浪sae
第一步需要注册新浪云 https://sae.sinacloud.com/ 第二步 创建应用,注:直接选python2.7不用纠结,后面可以指定python版本,共享版 第三步 找到git仓库信息 第 ...
- 非常强力的reduce
Array 的方法 reduce 是一个有非常多用处的函数. 它一个非常具有代表性的作用是将一个数组转换成一个值.但是你可以用它来做更多的事. 1.使用"reduce"代替&quo ...