python使用mysql的一些坑

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 注意:如果你用的是python3.x,直接去看第四个问题遇到的第一个问题正常来说直接执行pip安装,就是可以的,但是MySQL-python偏偏比较独特pip install MySQL-python报错_mysql.

注意:如果你用的是python3.x,直接去看第四个问题

遇到的第一个问题

  • 正常来说直接执行pip安装,就是可以的,但是MySQL-python偏偏比较独特

    pip install MySQL-python
  • 报错

    _mysql.c:44:10: fatal error: 'my_config.h' file not found
        #include "my_config.h"
                 ^~~~~~~~~~~~~
        1 error generated.
        error: command 'cc' failed with exit status 1

解决第一个问题

  • 执行brew install mysql-connector-c

    brew install mysql-connector-c
  • 如果这一步直接完成,那就可以继续pip install MySQL-python,应该会成功
  • 但是我在这一步执行失败了

遇到第二个问题

  • brew install mysql-connector-c报错

    Error: Cannot install mysql-connector-c because conflicting formulae are installed.
      mysql: because both install MySQL client libraries
    
    Please `brew unlink mysql` before continuing.

解决第二个问题

  • 按照报错的提示,执行brew unlink mysql
  • 没有发生什么意外,执行完毕,继续执行brew install mysql-connector-c
  • 'mysql-connector-c'安装成功
  • 执行brew link --overwrite mysql,重新连接mysql(这一步我没有做)
  • 然后再执行pip install MySQL-python,如果成功了就搞定了
  • 神奇的是,我在这一步又失败了

遇到的第三个问题

  • 上面的步骤走完以后,执行pip install MySQL-python,报错

    Collecting mysql
      Downloading https://files.pythonhosted.org/packages/06/ef/c4efbf2a51fb46aba9be03a973638d9539c9ca10a5259b2cbb1a66133b2e/mysql-0.0.1.tar.gz
    Collecting MySQL-python (from mysql)
      Using cached https://files.pythonhosted.org/packages/a5/e9/51b544da85a36a68debe7a7091f068d802fc515a3a202652828c73453cad/MySQL-python-1.2.5.zip
        Complete output from command python setup.py egg_info:
        Traceback (most recent call last):
          File "<string>", line 1, in <module>
          File "/private/var/folders/zn/t8xxx4m149s9jqp1810ndrz80000gn/T/pip-install-oHMKPE/MySQL-python/setup.py", line 17, in <module>
    metadata, options = get_config()
          File "setup_posix.py", line 53, in get_config
    libraries = [ dequote(i[2:]) for i in libs if i.startswith(compiler_flag("l")) ]
          File "setup_posix.py", line 8, in dequote
    if s[0] in "\"'" and s[0] == s[-1]:
        IndexError: string index out of range

解决第三个问题

  • 修改mysql的配置文件mysql_config修改前记得cp一下
    执行mysql_config,查看一下路径
  • 打开文件vim mysql_config,找到libs="$libs -l ",改为libs="$libs -lmysqlclient -lssl -lcrypto "

    libs="-L$pkglibdir"
    # libs="$libs -l "                              # 原来的
    libs="$libs -lmysqlclient -lssl -lcrypto "      # 更改后的
    embedded_libs="-L$pkglibdir"
    embedded_libs="$embedded_libs -l "
  • 再来一遍pip install MySQL-python
  • 终于成功了!可喜可贺!可喜可贺!
  • 小心翼翼的试一下,import MySQLdb,真的成功了

发现第四个问题

  • 开始使用的时候,发现自己用的是python2.x的环境,换成python3.x继续用
  • import MySQLdb的时候又出问题了,ModuleNotFoundError: No module named 'MySQLdb'
  • 尝试使用pip3 install MySQL-python再安装一次,报错

    Collecting MySQL-python
      Using cached https://files.pythonhosted.org/packages/a5/e9/51b544da85a36a68debe7a7091f068d802fc515a3a202652828c73453cad/MySQL-python-1.2.5.zip
        Complete output from command python setup.py egg_info:
        Traceback (most recent call last):
          File "<string>", line 1, in <module>
          File "/private/var/folders/07/v8slhf9x5zsbbd8_9cd5ztnh0000gp/T/pip-install-oh_74ez5/MySQL-python/setup.py", line 13, in <module>
    from setup_posix import get_config
          File "/private/var/folders/07/v8slhf9x5zsbbd8_9cd5ztnh0000gp/T/pip-install-oh_74ez5/MySQL-python/setup_posix.py", line 2, in <module>
    from ConfigParser import SafeConfigParser
        ModuleNotFoundError: No module named 'ConfigParser'
    
        ----------------------------------------
    Command "python setup.py egg_info" failed with error code 1 in /private/var/folders/07/v8slhf9x5zsbbd8_9cd5ztnh0000gp/T/pip-install-oh_74ez5/MySQL-python/

解决第四个问题

  • 查到了原因,感到一阵阵的无语

In Python 3, ConfigParser has been renamed to configparser for PEP 8 compliance. It looks like the package you are installing does not support Python 3.
在Python3中,ConfigParser为了符合PEP8规范,已重命名为configparser。看起来你正在安装的软件包不支持Python3。

  • 因为不支持python3,建议使用pip install pymysql,安装也没那么多套路
  • 其实也找到了解决方案(没有测试,我也不知道对不对,单纯的记录一下)

    • 方法一, 修改six模块为

      try:
          import configparser
      except:
          from six.moves import configparser
    • 方法二

      cp /usr/local/lib/python3.7/configparser.py /usr/local/lib/python3.7/ConfigParser.py

参考链接:时光不写博客-_mysql.c:44:10:fatal error:'my_config.h'...

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
python操作mysql
python操作mysql
|
1月前
|
JSON 关系型数据库 数据库
【python】Python将100个PDF文件对应的json文件存储到MySql数据库(源码)【独一无二】
【python】Python将100个PDF文件对应的json文件存储到MySql数据库(源码)【独一无二】
【python】Python将100个PDF文件对应的json文件存储到MySql数据库(源码)【独一无二】
|
12天前
|
SQL 关系型数据库 MySQL
使用Python的pymysql库连接MySQL,执行CRUD操作
使用Python的pymysql库连接MySQL,执行CRUD操作:安装pymysql,然后连接(host=&#39;localhost&#39;,user=&#39;root&#39;,password=&#39;yourpassword&#39;,database=&#39;yourdatabase&#39;),创建游标。查询数据示例:`SELECT * FROM yourtable`;插入数据:`INSERT INTO yourtable...`;更新数据:`UPDATE yourtable SET...`;删除数据:`DELETE FROM yourtable WHERE...`。
26 0
|
13天前
|
SQL 关系型数据库 MySQL
Python操作mysql数据库
Python操作mysql数据库
|
17天前
|
缓存 NoSQL 关系型数据库
在Python Web开发过程中:数据库与缓存,MySQL和NoSQL数据库的主要差异是什么?
MySQL与NoSQL的主要区别在于数据结构、查询语言和可扩展性。MySQL是关系型数据库,依赖预定义的数据表结构,使用SQL进行复杂查询,适合垂直扩展。而NoSQL提供灵活的存储方式(如JSON、哈希表),无统一查询语言,支持横向扩展,适用于处理大规模、非结构化数据和高并发场景。选择哪种取决于应用需求、数据模型及扩展策略。
26 0
|
22天前
|
SQL 关系型数据库 MySQL
Python与MySQL数据库交互:面试实战
【4月更文挑战第16天】本文介绍了Python与MySQL交互的面试重点,包括使用`mysql-connector-python`或`pymysql`连接数据库、执行SQL查询、异常处理、防止SQL注入、事务管理和ORM框架。易错点包括忘记关闭连接、忽视异常处理、硬编码SQL、忽略事务及过度依赖低效查询。通过理解这些问题和提供策略,可提升面试表现。
34 6
|
29天前
|
SQL 关系型数据库 MySQL
「Python系列」Python MySQL
在Python中使用MySQL数据库通常涉及使用一个称为`mysql-connector-python`的库,这是MySQL官方推荐的Python连接器。下面是如何在Python中连接到MySQL数据库、执行查询和插入数据的基本步骤。
33 1
|
2月前
|
SQL 关系型数据库 MySQL
Python怎么操作Mysql数据库
Python怎么操作Mysql数据库
56 0
|
2月前
|
SQL 关系型数据库 MySQL
python如何操作mysql数据库
python如何操作mysql数据库
26 0
|
9月前
|
SQL 关系型数据库 MySQL
[Python]使用Python操作MySQL数据库(pymysql)
[Python]使用Python操作MySQL数据库(pymysql)