Python3中使用flask_sqlalchemy的问题_python3用不了sqlalchemy吗-程序员宅基地

技术标签: Python_web开发  flask_sqlalchemy  

1.Flask-SQLAlchemy

Flask-SQLAlchemy 是Flask的数据库扩展,简化了Flask程序中使用 SQLAlchemy的操作,和其他Flask扩展一样,Flask-SQLAlchemy 也使用 pip 安装:

pip install flask-sqlalchemy
2. 常见的问题

问题一
Python3在flask_sqlalchemy中相比改动了一些比如模块的导入。
在Python2中应该是

from flask.ext.sqlalchemy impot SQLAlchemy

在Python3中使用

from flask_sqlalchemy import  SQLAlchemy

这一点对于其余的Flask扩展也是一样.导入包的结构与python2中有了改动.

问题二
flask-sqlalchemy的使用的时候,没有配置SQLALCHEMY_TRACK_MODIFICATIONS 这个参数,如果没有配置改参数,在运行程序的时候会报异常.

/home/air/Desktop/microblog/flask/local/lib/python2.7/site-packages/flask_sqlalchemy/__init__.py:839: FSADeprecationWarning: SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future.  Set it to True or False to suppress this warning.  
  'SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and ' 

提示我们需要设定参数‘True’ 或者 ‘’Flase‘
是说SQLALCHEMY_TRACK_MODIFICATIONS不能默认什么都没有,
得设置其为 True 或者 False,
所以就去/flask/local/lib/python2.7/site-packages/flask_sqlalchemy/init.py这个文件中进行更改,
提示给的839行,在前面几行的位置有这样的setdefault,
把None改为True;:

...
 833            track_modifications = app.config.setdefault(
 834             'SQLALCHEMY_TRACK_MODIFICATIONS', True #这里,一开始是None需要改变为True or Flase
 835         )
...

问题三
Python3与Python2中数据库连接URI的也是有区别的.以mysql为例,

python2

SQLALCHEMY_DATABASE_URI = 'mysql://root:[email protected]/tushare?charset=utf8' #这是Python2的

Python3

SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:[email protected]/tushare?charset=utf8' #这是Python3的

如果按照python2 的写法会出现一下错误

ModuleNotFoundError: No module named 'MySQLdb'

出现此异常的原因是因为在python2中连接mysql数据库使用的是MySQLdb,而在python3中连接mysql数据库使用的是pymysql,如果按照python2的写法配置数据库连接的URI,默认就会使用MySQLdb连接数据库,参考文档如下:
http://docs.sqlalchemy.org/en/rel_1_0/dialects/mysql.html#module-sqlalchemy.dialects.mysql.pymysql
所以解决这个问题一要修改数据库连接串的写法,二就是要安装pymysql

pip install pymysql
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq562029186/article/details/81325074

智能推荐

linux centos7安装redis_linux7安装redis客户端-程序员宅基地

文章浏览阅读312次。linux安装redis_linux7安装redis客户端

动态规划入门感悟_动态规划的基本思想及感悟-程序员宅基地

文章浏览阅读357次,点赞2次,收藏3次。不会动态规划的可以看看我博客里动态规划入门一文哦http://blog.csdn.net/qq_39670434/article/details/77414362在这里为了帮助萌新们学习动态规划,调用几篇大佬的好文章http://blog.csdn.net/baidu_28312631/article/details/47418773http://blog.csdn.net_动态规划的基本思想及感悟

单片机上电不断重启复位_stc8f单片机勾选低压复位单片机不断复位怎么解决-程序员宅基地

文章浏览阅读7.7k次,点赞4次,收藏15次。单片机不断重启复位的原因主要是一个原因;就是单片机在不断复位造成复位的原因有几个;1、单片机硬件复位,这个要检查硬件电路中的复位电路是不是有错误2、单片机程序中有代码造成软件复位3、单片机在不断上电断电循环过程造成不断复位主要讲一下第三种情况,这种情况的主要原因的因为外部电源供电不足导致单片机不断复位。你先检查一下自己的电路中是否有很多需要供电的模块,比如电机,制冷发热类的模块等等需要..._stc8f单片机勾选低压复位单片机不断复位怎么解决

哈尔滨工业大学计算机科学与技术学院许博文,王轩-哈尔滨工业大学(深圳)计算机科学与技术学院...-程序员宅基地

文章浏览阅读573次。一、近三年发表期刊论文[1]第一作者及通讯作者论文1)Yulin Wu, Xuan Wang, Zoe L. Jiang, etc. Efficient Server-Aided Secure Two-Party Computation in Heterogeneous Mobile Cloud Computing, IEEE Transactions on Dependable and Secu..._ansactions on dependable and secure computing

Prometheus源码学习(8) scrape总体流程_promethus scrapes-程序员宅基地

文章浏览阅读1.2k次。1. main 函数中初始化 scrapeManager 实例// 初始化 scrapeManager,fanout Storage 是一个读写多个底层存储的代理scrapeManager = scrape.NewManager(log.With(logger, "component", "scrape manager"), fanoutStorage)fanoutStorage 是读写多个底层存储的代理,实现了 storage.Appendable 接口。scrape.Manager 结构体._promethus scrapes

Windows10 Atom安装和运行Python的使用教程(详细)-程序员宅基地

文章浏览阅读2.6w次,点赞19次,收藏85次。目录一、下载Atom二、Atom安装Python相关组件1.检查Python库支持2.安装Python的适合Atom的IDE、UI、Server和运行工具*三、运行代码范例(爬取以杉原杏璃为关键字的百度图片)一、下载Atom1.官网:Atom官网2.打开这个网页,可以看到Atom针对于操作系统Windows7或以上的版本3.下载完成,双击exe4.加..._atom安装

随便推点

ubuntu怎么卸载matlab,卸载Ubuntu下Matlab (uninstall matlab2009 for linux)-程序员宅基地

文章浏览阅读422次。2.在/var目录搜索lm,我只找到以lm-sensors开头的文件,而lm-sensors是一个硬件状况监视器,用来得到温度、电压、风扇速度传感器信我在matlab官网搜到如下帮助文档Problem Description:I would like to uninstall MATLAB on a UNIX or Linux machine.Solution:There is not unins..._ubantu 无法移除matlab

运算放大器的关键指标详解二(噪声)_运放pid电路的噪声-程序员宅基地

文章浏览阅读2.1w次,点赞43次,收藏192次。噪声指标(Noise)一个正常工作的放大电路,当输入端接地时,用示波器观察输出,你看到的可能不是平直的细线,而是在一定幅度之内的杂乱无章的波形。这就是噪声。 你在示波器上看到线越粗,就说明噪声幅度越大。放大电路的输出端噪声,小至 μV 以下,大至百 mV 以上,完全取决于电路设计,能否在示波器上看见,则取决于示波器选择和设置。噪声定义:1) 它的波形在任意时刻都是不确定的,因此它是广谱的,有低频也有高频;2) 它的幅度又是有限制的,这与数学上的高斯分布近似但不完全一致;3) 它具有无限积分趋零性_运放pid电路的噪声

数据分析案例分析:日化公司社群营销场景,产品SKU,用户转化率,用户流转地图_leads数-程序员宅基地

文章浏览阅读3k次。近期参加了一个业务数据分析的3天课程,锻炼自己的业务实例数据分析能力。接下来的内容是第一天课程的作业,里面涉及到许多自己的知识盲区(社群营销,产品SKU,用户转化率,用户流转地图)。分享在这里,期待感兴趣的同志们多多指点~目录作业要求问题分析背景分析概念厘清1. 社群营销是什么?拉群卖货吗?2. 产品SKU3. 用户转化率Q2为什么展示后4张图(图6-图9)【作业点评总结Q2】Q1 从图中看,存在什么问题,出现这些问题的原因是什么Step1. 分..._leads数

数据库多维度水平切分设想 --- 分库,分表,多维度,水平切分,mysql,负载均衡_ssas 加入维度后数据没有切分-程序员宅基地

文章浏览阅读3k次。随着互联网应用的普及,海量数据存储早已经成了大型网站技术人员关注的焦点。每天上亿的访问量对数据库的压力可想而知。因此,为了维持数据库的稳定性和可扩展性,我们常常选择在业务垂直切分的基础上(抽象出业务中心单元如用户中心),再进行数据库的水平切分。 那么为什么要进行数据库的水平切分呢?有些人会说,如果单台数据库服务器过载过高,则可以采用replication的机制,分别指定读写服务器实现读写_ssas 加入维度后数据没有切分

eclipse中导航栏名称主要功能_echarls的导航栏意思-程序员宅基地

文章浏览阅读375次。A-mapper 里面主要写数据库的A-parent 类,父类方法A-pojo POJO实质上可以理解为简单的实体类,顾名思义POJO类的作用是方便程序员使用数据库中的数据表,对于广大的程序员,可以很方便的将POJO类当做对象来进行使用,当然也是可以方便的调用其get,set方法。POJO类也给我们在struts框架中的配置带来了很大的方便。A-service 提供与数据..._echarls的导航栏意思

WebSocket 的 PHP 实现 - phpwebsocket_websocket chr(1)-程序员宅基地

文章浏览阅读1.3k次。从名字上也可看出,这是一个 WebSocket 的 PHP 实现。示例客户端代码:1var host = "ws://localhost:12345/websocket/server.php";2try{3 socket = new WebSocket(host);_websocket chr(1)

推荐文章

热门文章

相关标签