位置: 编程技术 - 正文

Python的Flask框架中SQLAlchemy使用时的乱码问题解决(flask框架菜鸟教程)

编辑:rootadmin

推荐整理分享Python的Flask框架中SQLAlchemy使用时的乱码问题解决(flask框架菜鸟教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python的flask框架干啥的,flask框架下使用scrapy框架,python的flask框架干啥的,Python的flask框架教程,flask 框架,flask 框架,flask 框架,python的flask框架干啥的,内容如对您有帮助,希望把文章链接给更多的朋友!

一、问题

这两天在学习使用flask + SQLAlchemy 定制一个web查询页面的demo ,在测试时,发现查询到的结果显示乱码 。这里将解决方法记录下。

二、解决思路

1、flask 程序上定位

flask的文档中提到可以通过设置SQLALCHEMY_NATIVE_UNICODE来禁止使用SQLAlchemy默认的Unicode编码。有可能是SQLAlchemy默认的Unicode编码不是UTF-8,抱着这样的想法,在程序中指定了“SQLALCHEMY_NATIVE_UNICODE=False”,执行程序,报错。

flask中还提到“use_native_unicode”为目标编码来指定编码方式,尝试将“db = SQLAlchemy(app)”改为“db = SQLAlchemy(app, use_native_unicode="utf8")”。这回虽然没报错,但还是乱码。

Python的Flask框架中SQLAlchemy使用时的乱码问题解决(flask框架菜鸟教程)

2、mysql 上定位

突然想到有可能是建表的时候,没有指定字符集,使用的是数据库默认的字符集的导致的。继续找了一段时间的如何指定建表时使用字符集的方法,未果。

数据库该不会使用的不是UTF-8吧?抱着这个想法,进入数据库,输入“status”,在输出的信息上显示默认是latin-1。搞了半天,原来问题在这。

3、解决问题

即然找到了,问题就在mysql 的my.cnf 上增加相关配置,并重启mysql 服务:

注:需要注意的是,之前已经存在的数据,在上面修改过后,通过mysql select查询时会是乱码,需要重新导入。

PS:Python下SQLAlchemy真的是super好用,不太了解的童鞋可以尝试一下下面这个MySQL的例子:

用Python的Flask框架结合MySQL写一个内存监控程序 这里以监控内存使用率为例,写的一个简单demo性程序,具体操作根据reboot提供的教程写如下。一、建库建表创建falcon数据库:mysqlcreatedatabasefalconcharact

Python实现模拟时钟代码推荐 Python实现模拟时钟代码推荐#coding=utf8importsys,pygame,math,randomfrompygame.localsimport*fromdatetimeimportdatetime,date,timedefprint_text(font,x,y,text,color=(,,)):imgtext=font.re

使用Python对IP进行转换的一些操作技巧小结 PythonSocket模块中包含一些有用IP转换函数,说明如下:socket.ntohl(x)//类似于C语言的ntohl(x)把位正整数从网络序转换成主机字节序。socket.ntohs(x)//类似于C

标签: flask框架菜鸟教程

本文链接地址:https://www.jiuchutong.com/biancheng/378561.html 转载请保留说明!

上一篇:举例讲解Linux系统下Python调用系统Shell的方法(简单介绍linux系统有哪些主要特点?)

下一篇:用Python的Flask框架结合MySQL写一个内存监控程序(python中flask模块)

  • 浅析SQL Server的分页方式 ISNULL与COALESCE性能比较(sql server干嘛的)

    我们看到上述COALESCE合并的结果是可空的而ISNULL不是,有一点点不同。

    (3)COALESCE对列计算时需要持久化

    接下来我们看看二者最大的不同,我们通过计算列并且在其上面创建主键或者非空约束,看看ISNULL和COALESCE的区别

    我们再来看看COALESCE函数来计算列

    很明显我们需要对列进行持久化,通过添加PERSISTED关键字,如下即可。

    我们再来看看一个二者的不同

    我们到这里其实我们可以稍微概括下二者的区别:ISNULL着重于替换,而COALESCE着重于合并。COALESCE显示忽略了NULL并用空字符串填充并压缩,而ISNULL对NULL会用空字符串填充但不会压缩。

    (4)COALESCE函数支持超过两个参数

    对于多个参数输入,ISNULL函数需要嵌套调用,而COALESCE能够处理任何数量,至于上限不知,所以对于多个参数使用COALESCE更加,如下使用多个参数输入。

    SELECT COALESCE(a, b, c, d, e, f, g) FROM dbo.table;

    而对于ISNULL,我们需要这样做

    SELECT ISNULL(a, ISNULL(b, ISNULL(c, ISNULL(d, ISNULL(e, ISNULL(f, g)))))) FROM dbo.table;

    二者最终执行时和利用CASE一样

    (5)COALESCE和ISNULL二者性能比较

    我们来运行如下查询

    我们有查询四个场景:(1)两个参数都为NULL(2)第一个参数为NULL(3)第二个参数为NULL(4)两个参数都为NULL。每个场景测试十次,最终得出如下结果

    从上看出二者性能并未有什么太大差异,我们不需要太担心了吧,当然上述场景并未完全覆盖,至少还是能说明一部分。上述我们得到的结果查看的执行时间,现在我们再来看看二者查询执行计划。

    上述可能不太准确,还和硬件配置有关,也有可能COALESCE的性能差与ISNULL。二者性能应该是没什么很大差异。

    (6)ISNULL和自然语言描述不一致

    为何是和自然语言描述不一致呢?也就是说我们当判断某个值为NULL会做什么,不为NULL再做什么,这时用查询语言SQL描述如下:

    我们用自然语言角度来看,翻译为如果something为NULL我们做什么,这个时候是不一致的。因为在SQL Server中没有布尔值类型,上述我们只能进行如下转换

    (7)利用GUID看看奇葩的ISNULL

    在本节介绍之前我们再来看看一个例子,从而颠覆你的想法,让你发狂。

    SELECT ISNULL(NEWID(), 'JeffckyWang" class="img-responsive" alt="浅析SQL Server的分页方式 ISNULL与COALESCE性能比较(sql server干嘛的)">

    浅析SQL Server的分页方式 ISNULL与COALESCE性能比较(sql server干嘛的)

  • 使用hostapd和dhcpd来在Ubuntu上开启无线热点(使用dhcp的好处有哪些)

    使用hostapd和dhcpd来在Ubuntu上开启无线热点(使用dhcp的好处有哪些)

  • Win8.1官方正版怎么使用电话在线免费激活?(windows8.1正版)

    Win8.1官方正版怎么使用电话在线免费激活?(windows8.1正版)

  • 如何调整输入法的切换顺序?使用win7注册表调整输入法顺序的方法(如何调整输入法框的大小)

    如何调整输入法的切换顺序?使用win7注册表调整输入法顺序的方法(如何调整输入法框的大小)

  • javascript学习笔记(八) js内置对象(javascript总结笔记)

    javascript学习笔记(八) js内置对象(javascript总结笔记)

  • 补缴以前年度增值税和罚款、滞纳金的所得税处理
  • 建筑垃圾清运费税率是多少
  • 蔬菜开税票纳税吗
  • 差额征税劳务费发票
  • 深圳重工业企业有哪些
  • 建筑类没收入怎么填
  • 有留抵税额可以享受加计抵减吗
  • 应收账款资产减值损失转回和核销的区别
  • 企业所得税连续3年亏损预警自查报告
  • 购物开了增值税怎么退
  • 申报所得税营业税怎么算
  • 携程电子发票可以发到QQ邮箱吗
  • 小规模纳税人开具1%增值税专用发票可以抵扣吗
  • 企业恢复生产经营方案
  • 收到测试费几分钱如何做账
  • 民办教育培训机构申请条件
  • 旧税号的发票专用章还能使用吗
  • 分期收款发出商品属于什么科目
  • 法人股东分红如何申报所得税
  • 连接另外一个设备
  • 企业财政拨款所得免税吗
  • 银行与银行之间转账会计摘要
  • win10永久激活码神key一周内
  • 解决网卡驱动故障的方法
  • 苹果电脑快速启动键是哪个
  • PHP:bzdecompress()的用法_Bzip2函数
  • 固定资产的税务筹划
  • mediacachefiles什么意思
  • php数据表
  • 建筑公司结算会计
  • 土地增值税的意思
  • 抵债资产怎么入账
  • php数组操作
  • 生产企业计提车折旧年限
  • yii2实现根据时间搜索的方法
  • 微信公众号开发php源码
  • pgadmin配置
  • phpweb缓存技术
  • 施工水电费账务处理流程
  • SQLite教程(十一):临时文件
  • SQL Server 2016 TempDb里的显著提升
  • 应付职工薪酬期末余额是什么意思
  • 差旅费报销范文
  • 营业成本的构成
  • 企业需要购买两种保险吗
  • 小企业会计准则适用范围
  • 购销合同印花税税率表
  • 税控盘维护费280账务处理
  • 记账凭证错误的更正方法
  • 税务稽查补缴上年所得税分录
  • 哈罗单车说明
  • 商业折扣怎么扣
  • 企业验资的好处
  • 非居民企业股权转让特殊性税务处理
  • pe市盈率法
  • 劳务公司发放农民工工资要交个税吗
  • 发票监制章是什么章图片
  • 年末出现打一数字
  • 施工企业其他业务收入包括哪些
  • 结账时能否用红笔写名字
  • linux 使用技巧
  • vmwarevmx进程是干嘛的
  • 双屏windows
  • win7win8win10哪个流畅
  • windows8.1应用商店打不开
  • win7怎么删除右键菜单
  • win10专业版怎么改用户名
  • win7如何禁用网卡
  • linux挂载啥意思
  • opengl绘制ui
  • node搭建博客
  • css的基础
  • js中排序的函数
  • unity gpu优化
  • 浅谈编码,解码的意义
  • js中的
  • js复制字符串的方法
  • javascript截图找图
  • jquery单选框
  • javascript与java
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设