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的更多相关文章

  1. python 全栈开发,Day142(flask标准目录结构, flask使用SQLAlchemy,flask离线脚本,flask多app应用,flask-script,flask-migrate,pipreqs)

    昨日内容回顾 1. 简述flask上下文管理 - threading.local - 偏函数 - 栈 2. 原生SQL和ORM有什么优缺点? 开发效率: ORM > 原生SQL 执行效率: 原生 ...

  2. flask插件系列之SQLAlchemy基础使用

    sqlalchemy是一个操作关系型数据库的ORM工具.下面研究一下单独使用和其在flask框架中的使用方法. 直接使用sqlalchemy操作数据库 安装sqlalchemy pip install ...

  3. flask系列四之SQLAlchemy

    一.SQLAlchemy简介 (1)flask_sqlalchemy是一套ORM框架. (2)ORM(Object Relationship Mapping):模型关系映射 (3)ORM的好处:可以让 ...

  4. flask的orm框架(SQLAlchemy)-操作数据

    # 原创,转载请留言联系 Flask-SQLAlchemy 实现增加数据 用 sqlalchemy 添加数据时,一定要注意,不仅仅要连接到数据表,并且你的创建表的类也必须写进来.而且字段和约束条件要吻 ...

  5. flask的orm框架(SQLAlchemy)-创建表

    # 转载请留言联系 ORM 是什么? ORM,Object-Relation Mapping.意思就是对象-关系映射.ORM 主要实现模型对象到关系数据库数据的映射. 优点 : 只需要面向对象编程, ...

  6. Flask01 初识flask、创建flask应用、flask启动配置

    1 什么是flask Flask是一个使用 Python 编写的轻量级 Web 应用框架.其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2 . 百度百科:点击前往 中文文档: ...

  7. flask第一章 flask启动 路由视图 FlaskRequest jinja2 FlaskSession

    一.简单了解flask web框架 优点: 小而精,组件只有session,第三方机构强烈支持flask,极其简单 缺点: 由于第三方软件的关系,稳定性相对较差,flask-session 扩展知识: ...

  8. Flask最强攻略 - 跟DragonFire学Flask - 第九篇 Flask 中的蓝图(BluePrint)

    蓝图,听起来就是一个很宏伟的东西 在Flask中的蓝图 blueprint 也是非常宏伟的 它的作用就是将 功能 与 主服务 分开怎么理解呢? 比如说,你有一个客户管理系统,最开始的时候,只有一个查看 ...

  9. Flask系列(二)Flask基础

    知识点回顾 1.flask依赖wsgi,实现wsgi的模块:wsgiref(django),werkzeug(flask),uwsgi(上线) 2.实例化Flask对象,里面是有参数的 app = F ...

随机推荐

  1. 【poj3294】 Life Forms

    http://poj.org/problem?id=3294 (题目链接) 题意 给定 n 个字符串,求出现在不小于 k 个字符串中的最长子串. Solution 后缀数组论文题.. 将 n 个字符串 ...

  2. Android Intent 总结

    //打开指定网页Intent intent = new Intent(Intent.ACTION_VIEW);intent.setData(Uri.parse("http://www.goo ...

  3. LigerUI下拉选择列表LigerComboBox中tree的节点初始化默认选中的问题

    问题描述 用后台的Json传送tree的数据 前端用js方法来控制选中节点 此方法存在bug 实例: bug问题:无论设置的默认选中值是多少个,前台checkbox最多只显示选中一个,但是内容框中显示 ...

  4. unity还原three——顶点,三角面,uv

    public class Geometry { public Geometry(string name, Data data, Hashtable hash) { Debug.Log("解析 ...

  5. NATS_10:NATS服务配置文件详解

    尽管NATS可以无配置的运行,但也可以使用配置文件配置NATS服务的启动,在实际应用当中,一般都是通过使用配置文件来启动服务的. 1. 配置项包括 客户端监听器端口 Client listening ...

  6. gitlab的备份与恢复与迁移

    一.gitlab的备份1.1 创建备份目录,并授权 1 2 3 4 [root@linux-node1 ~]# mkdir /data/backups/gitlab -p [root@linux-no ...

  7. 51 nod 1105 第K大的数

    1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题  收藏  关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...

  8. hive架构原理简析-mapreduce部分

    整个处理流程包括主要包括,语法解析(抽象语法树,AST,采用antlr),语义分析(sematic Analyzer生成查询块),逻辑计划生成(OP tree),逻辑计划优化,物理计划生成(Task ...

  9. python3 flask部署新浪sae

    第一步需要注册新浪云 https://sae.sinacloud.com/ 第二步 创建应用,注:直接选python2.7不用纠结,后面可以指定python版本,共享版 第三步 找到git仓库信息 第 ...

  10. 非常强力的reduce

    Array 的方法 reduce 是一个有非常多用处的函数. 它一个非常具有代表性的作用是将一个数组转换成一个值.但是你可以用它来做更多的事. 1.使用"reduce"代替&quo ...