Skip to main content

Python interface to MySQL

Project description


This project is a fork of MySQLdb1. This project adds Python 3 support and fixed many bugs.


Do Not use Github Issue Tracker to ask help. OSS Maintainer is not free tech support

When your question looks relating to Python rather than MySQL:

Or when you have question about MySQL:



Building mysqlclient on Windows is very hard. But there are some binary wheels you can install easily.

If binary wheels do not exist for your version of Python, it may be possible to build from source, but if this does not work, do not come asking for support. To build from source, download the MariaDB C Connector and install it. It must be installed in the default location (usually "C:\Program Files\MariaDB\MariaDB Connector C" or "C:\Program Files (x86)\MariaDB\MariaDB Connector C" for 32-bit). If you build the connector yourself or install it in a different location, set the environment variable MYSQLCLIENT_CONNECTOR before installing. Once you have the connector installed and an appropriate version of Visual Studio for your version of Python:

$ pip install mysqlclient

macOS (Homebrew)

Install MySQL and mysqlclient:

$ # Assume you are activating Python 3 venv
$ brew install mysql pkg-config
$ pip install mysqlclient

If you don't want to install MySQL server, you can use mysql-client instead:

$ # Assume you are activating Python 3 venv
$ brew install mysql-client pkg-config
$ export PKG_CONFIG_PATH="$(brew --prefix)/opt/mysql-client/lib/pkgconfig"
$ pip install mysqlclient


Note that this is a basic step. I can not support complete step for build for all environment. If you can see some error, you should fix it by yourself, or ask for support in some user forum. Don't file a issue on the issue tracker.

You may need to install the Python 3 and MySQL development headers and libraries like so:

  • $ sudo apt-get install python3-dev default-libmysqlclient-dev build-essential pkg-config # Debian / Ubuntu
  • % sudo yum install python3-devel mysql-devel pkgconfig # Red Hat / CentOS

Then you can install mysqlclient via pip now:

$ pip install mysqlclient

Customize build (POSIX)

mysqlclient uses pkg-config --cflags --ldflags mysqlclient by default for finding compiler/linker flags.

You can use MYSQLCLIENT_CFLAGS and MYSQLCLIENT_LDFLAGS environment variables to customize compiler/linker options.

$ export MYSQLCLIENT_CFLAGS=`pkg-config mysqlclient --cflags`
$ export MYSQLCLIENT_LDFLAGS=`pkg-config mysqlclient --libs`
$ pip install mysqlclient


Documentation is hosted on Read The Docs

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mysqlclient-2.2.4.tar.gz (90.4 kB view hashes)

Uploaded Source

Built Distributions

mysqlclient-2.2.4-pp310-pypy310_pp73-win_amd64.whl (203.2 kB view hashes)

Uploaded PyPy Windows x86-64

mysqlclient-2.2.4-pp39-pypy39_pp73-win_amd64.whl (203.4 kB view hashes)

Uploaded PyPy Windows x86-64

mysqlclient-2.2.4-pp38-pypy38_pp73-win_amd64.whl (203.5 kB view hashes)

Uploaded PyPy Windows x86-64

mysqlclient-2.2.4-cp312-cp312-win_amd64.whl (203.3 kB view hashes)

Uploaded CPython 3.12 Windows x86-64

mysqlclient-2.2.4-cp311-cp311-win_amd64.whl (203.2 kB view hashes)

Uploaded CPython 3.11 Windows x86-64

mysqlclient-2.2.4-cp310-cp310-win_amd64.whl (203.2 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

mysqlclient-2.2.4-cp39-cp39-win_amd64.whl (203.3 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

mysqlclient-2.2.4-cp38-cp38-win_amd64.whl (203.3 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page