Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/PyMySQL/mysqlclient
MySQL database connector for Python (with Python 3 support)
https://github.com/PyMySQL/mysqlclient
mysql python
Last synced: 3 months ago
JSON representation
MySQL database connector for Python (with Python 3 support)
- Host: GitHub
- URL: https://github.com/PyMySQL/mysqlclient
- Owner: PyMySQL
- License: gpl-2.0
- Created: 2014-04-28T05:09:06.000Z (over 10 years ago)
- Default Branch: main
- Last Pushed: 2024-03-31T13:30:06.000Z (10 months ago)
- Last Synced: 2024-07-18T12:57:26.969Z (6 months ago)
- Topics: mysql, python
- Language: Python
- Homepage: https://mysqlclient.readthedocs.io/
- Size: 1.81 MB
- Stars: 2,428
- Watchers: 55
- Forks: 432
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.rst
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-mysql - mysqlclient-python - MySQL database connector for Python. (Connectors)
- best-of-python - GitHub - 3% open · ⏱️ 08.02.2024): (Database Clients)
- awesome-python-resources - GitHub - 4% open · ⏱️ 05.08.2022): (数据库 Drivers)
- awesome-list - mysqlclient - MySQL database connector for Python (Data Management & Processing / Database & Cloud Management)
README
# mysqlclient
This project is a fork of [MySQLdb1](https://github.com/farcepest/MySQLdb1).
This project adds Python 3 support and fixed many bugs.* PyPI: https://pypi.org/project/mysqlclient/
* GitHub: https://github.com/PyMySQL/mysqlclient## Support
**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/MariaDB:
* Python mailing list [python-list](https://mail.python.org/mailman/listinfo/python-list)
* Slack [pythondev.slack.com](https://pyslackers.com/web/slack)Or when you have question about MySQL/MariaDB:
* [MySQL Support](https://dev.mysql.com/support/)
* [Getting Help With MariaDB](https://mariadb.com/kb/en/getting-help-with-mariadb/)## Install
### Windows
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](https://mariadb.com/downloads/#connectors) 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:
```bash
$ # 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:
```bash
$ # 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
```### Linux
**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 / CentOSThen 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.```bash
$ export MYSQLCLIENT_CFLAGS=`pkg-config mysqlclient --cflags`
$ export MYSQLCLIENT_LDFLAGS=`pkg-config mysqlclient --libs`
$ pip install mysqlclient
```### Documentation
Documentation is hosted on [Read The Docs](https://mysqlclient.readthedocs.io/)