pymysql connect 连接mysql 报错keyerror255

MySQL 同时被 2 个专栏收录
26 篇文章 0 订阅
79 篇文章 2 订阅

摘要

pymysql connect 连接mysql 报错keyerror255;最近困了我两个多月的一个难题,搜这个标题进来的都可以看到搜索引擎提供了n^2篇解决方法的文章,那为什么还会困住我这么久呢?我不会百度吗?NO NO NO!!最大的问题是我的执行电脑和数据存储电脑不是同一台电脑!!

报错信息

  File "D:\Programfiles\Anaconda3\lib\site-packages\pymysql\connections.py", line 1269, in _get_server_information
    self.server_charset = charset_by_id(lang).name
  File "D:\Programfiles\Anaconda3\lib\site-packages\pymysql\charset.py", line 38, in by_id
    return self._by_id[id]
KeyError: 255

主要原因是MySQL8.0更新了很多字符集,但是这些字符集长度超过255了,所以旧版的PyMySQL不支持长度超过255的字符

网上可以查到很多解决这个问题的文章,方案一致,更新pymysql

pip install --upgrade pymysql

下面随便放了一篇,有兴趣的可以看看,不看也无所谓,全文总结就一句话更新pymysql,直接执行上面的更新代码,如果解决,ok !万事大吉,可以退出了,解决不了,放的这个链接文章看了意义也不大,继续往下看我的正文吧

django更换默认数据库sqlite3为pymsql后出现Keyerror:255的解决办法----升级PyMySQL

解决方案

正如前面所说,我的执行电脑和数据存储电脑不是同一台电脑!!
我自己电脑是mysql5.7,数据存储电脑版本是8.1
因为一开始公司网络安全升了次级,然后公司内网的VPN也更新了一次(大换血,界面都不一样了),
所以我一开始以为是网络安全策略导致的,
毕竟看网上全部是更新pymysql就行了,我已经最新了没法再新了

解决方案其实也就一句话,懒得绕弯子打那么多字了

  • 卸载重装Mysql

对!你没看错!就是Mysql数据库卸载了,然后重新装个8.0及以上版本的

所以主要原因还是一开始说的MySQL8.0更新了很多字符集,但是这些字符集长度超过255了


写在最后的拉票环节
最近参加了CSDN官方组织的“GEEK+”原创·博主大赛
历经重重筛选,终于上榜TOP 50
原创不易,帮忙投个免费的票
支持一下:点击投票
谢谢大家!!!

  • 5
    点赞
  • 8
    评论
  • 4
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 博客之星2020 设计师:CY__ 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值