aiomysql
========
.. image:: https://github.com/aio-libs/aiomysql/actions/workflows/ci-cd.yml/badge.svg?branch=master
:target: https://github.com/aio-libs/aiomysql/actions/workflows/ci-cd.yml
.. image:: https://codecov.io/gh/aio-libs/aiomysql/branch/master/graph/badge.svg
:target: https://codecov.io/gh/aio-libs/aiomysql
:alt: Code coverage
.. image:: https://badge.fury.io/py/aiomysql.svg
:target: https://badge.fury.io/py/aiomysql
:alt: Latest Version
.. image:: https://readthedocs.org/projects/aiomysql/badge/?version=latest
:target: https://aiomysql.readthedocs.io/
:alt: Documentation Status
.. image:: https://badges.gitter.im/Join%20Chat.svg
:target: https://gitter.im/aio-libs/Lobby
:alt: Chat on Gitter
**aiomysql** is a "driver" for accessing a `MySQL` database
from the asyncio_ (PEP-3156/tulip) framework. It depends on and reuses most
parts of PyMySQL_ . *aiomysql* tries to be like awesome aiopg_ library and
preserve same api, look and feel.
Internally **aiomysql** is copy of PyMySQL, underlying io calls switched
to async, basically ``yield from`` and ``asyncio.coroutine`` added in
proper places)). `sqlalchemy` support ported from aiopg_.
Documentation
-------------
https://aiomysql.readthedocs.io/
Basic Example
-------------
**aiomysql** based on PyMySQL_ , and provides same api, you just need
to use ``await conn.f()`` or ``yield from conn.f()`` instead of calling
``conn.f()`` for every method.
Properties are unchanged, so ``conn.prop`` is correct as well as
``conn.prop = val``.
.. code:: python
import asyncio
import aiomysql
async def test_example(loop):
pool = await aiomysql.create_pool(host='127.0.0.1', port=3306,
user='root', password='',
db='mysql', loop=loop)
async with pool.acquire() as conn:
async with conn.cursor() as cur:
await cur.execute("SELECT 42;")
print(cur.description)
(r,) = await cur.fetchone()
assert r == 42
pool.close()
await pool.wait_closed()
loop = asyncio.get_event_loop()
loop.run_until_complete(test_example(loop))
Example of SQLAlchemy optional integration
------------------------------------------
Sqlalchemy support has been ported from aiopg_ so api should be very familiar
for aiopg_ user.:
.. code:: python
import asyncio
import sqlalchemy as sa
from aiomysql.sa import create_engine
metadata = sa.MetaData()
tbl = sa.Table('tbl', metadata,
sa.Column('id', sa.Integer, primary_key=True),
sa.Column('val', sa.String(255)))
async def go(loop):
engine = await create_engine(user='root', db='test_pymysql',
host='127.0.0.1', password='', loop=loop)
async with engine.acquire() as conn:
await conn.execute(tbl.insert().values(val='abc'))
await conn.execute(tbl.insert().values(val='xyz'))
async for row in conn.execute(tbl.select()):
print(row.id, row.val)
engine.close()
await engine.wait_closed()
loop = asyncio.get_event_loop()
loop.run_until_complete(go(loop))
Requirements
------------
* Python_ 3.7+
* PyMySQL_
.. _Python: https://www.python.org
.. _asyncio: http://docs.python.org/3.5/library/asyncio.html
.. _aiopg: https://github.com/aio-libs/aiopg
.. _PyMySQL: https://github.com/PyMySQL/PyMySQL
.. _Tornado-MySQL: https://github.com/PyMySQL/Tornado-MySQL
Changes
-------
0.2.0 (2023-06-11)
^^^^^^^^^^^^^^^^^^
* Bump minimal SQLAlchemy version to 1.3 #815
* Remove deprecated Pool.get #706
* | Partially ported `PyMySQL#304 <https://github.com/PyMySQL/PyMySQL/pull/304>`_ #792
| aiomysql now reraises the original exception during connect() if it's not `IOError`, `OSError` or `asyncio.TimeoutError`.
| This was previously always raised as `OperationalError`.
* Fix debug log level with sha256_password authentication #863
* Modernized code with `pyupgrade <https://github.com/asottile/pyupgrade>`_ to Python 3.7+ syntax #930
* Removed tests for EoL MariaDB versions 10.3, 10.7 and 10.8, added tests for MariaDB 10.9, 10.10, 10.11 #932
0.1.1 (2022-05-08)
^^^^^^^^^^^^^^^^^^
* Fix SSL connection handshake charset not respecting client configuration #776
0.1.0 (2022-04-11)
^^^^^^^^^^^^^^^^^^
* Don't send sys.argv[0] as program_name to MySQL server by default #620
* Allow running process as anonymous uid #587
* Fix timed out MySQL 8.0 connections raising InternalError rather than OperationalError #660
* Fix timed out MySQL 8.0 connections being returned from Pool #660
* Ensure connections are properly closed before raising an OperationalError when the server connection is lost #660
* Ensure connections are properly closed before raising an InternalError when packet sequence numbers are out of sync #660
* Unix sockets are now internally considered secure, allowing sha256_password and caching_sha2_password auth methods to be used #695
* Test suite now also tests unix socket connections #696
* Fix SSCursor raising InternalError when last result was not fully retrieved #635
* Remove deprecated no_delay argument #702
* Support PyMySQL up to version 1.0.2 #643
* Bump minimal PyMySQL version to 1.0.0 #713
* Align % formatting in Cursor.executemany() with Cursor.execute(), literal % now need to be doubled in Cursor.executemany() #714
* Fixed unlimited Pool size not working, this is now working as documented by passing maxsize=0 to create_pool #119
* Added Pool.closed property as present in aiopg #463
* Fixed SQLAlchemy connection context iterator #410
* Fix error packet handling for SSCursor #428
* Required python version is now properly documented in python_requires instead of failing on setup.py execution #731
* Add rsa extras_require depending on PyMySQL[rsa] #557
* Migrate to PEP 517 build system #746
* Self-reported `__version__` now returns version generated by `setuptools-scm` during build, otherwise `'unknown'` #748
* Fix SSCursor raising query timeout error on wrong query #428
0.0.22 (2021-11-14)
^^^^^^^^^^^^^^^^^^^
* Support python 3.10 #505
0.0.21 (2020-11-26)
^^^^^^^^^^^^^^^^^^^
* Allow to use custom Cursor subclasses #374
* Fill Connection class with actual client version #388
* Fix legacy __aiter__ methods #403
* Fix & update docs #418 #437
* Ignore pyenv's .python-version file #424
* Replace asyncio.streams.IncompleteReadError with asyncio.IncompleteReadError #460 #454
* Add support for SQLAlchemy default parameters #455 #466
* Update dependencies #485
* Support Python 3.7 & 3.8 #493
0.0.20 (2018-12-19)
^^^^^^^^^^^^^^^^^^^
* Fixed connect_timeout #360
* Fixed support for SQLA executemany #324
* Fix the python 3.7 compatibility #357
* Fixed reuse connections when StreamReader has an exception #339
* Fixes warning when inserting binary strings #326
0.0.19 (2018-07-12)
^^^^^^^^^^^^^^^^^^^
* See v0.0.18
0.0.18 (2018-07-09)
^^^^^^^^^^^^^^^^^^^
* Updated to support latest PyMySQL changes.
* aiomysql now sends client connection info.
* MySQL8+ Support including sha256_password and cached_sha2_password authentication plugins.
* Default max packet length sent to the server is no longer 1.
* Fixes issue where cursor.nextset can hang on query sets that raise errors.
0.0.17 (2018-07-06)
^^^^^^^^^^^^^^^^^^^
* Pinned version of PyMySQL
0.0.16 (2018-06-03)
^^^^^^^^^^^^^^^^^^^
* Added ability to execute precompiled sqlalchemy queries #294 (Thanks @vlanse)
0.0.15 (2018-05-20)
^^^^^^^^^^^^^^^^^^^
* Fixed handling of user-defined types for sqlalchemy #290
* Fix KeyError when server reports unknown collation #289
0.0.14 (2018-04-22)
^^^^^^^^^^^^^^^^^^^
* Fixed SSL connection finalization #282
0.0.13 (2018-04-19)
^^^^^^^^^^^^^^^^^^^
* Added SSL support #280 (Thanks @terrycain)
* Fixed __all__ in aiomysql/__init__ #270 (Thanks @matianjun1)
* Added docker fixtures #275 (Thanks @terrycain)
0.0.12 (2018-01-18)
^^^^^^^^^^^^^^^^^^^
* Fixed support for SQLAlchemy 1.2.0
* Fixed argument for cursor.execute in sa engine #239 (Thanks @NotSoSuper)
0.0.11 (2017-12-06)
^^^^^^^^^^^^^^^^^^^
* Fixed README formatting on pypi
0.0.10 (2017-12-06)
^^^^^^^^^^^^^^^^^^^
* Updated regular expressions to be compatible with pymysql #167 (Thanks @AlexLisovoy)
* Added connection recycling in the pool #216
0.0.9 (2016-09-14)
^^^^^^^^^^^^^^^^^^
* Fixed AttributeError in _request_authentication function #104 (Thanks @ttlttl)
* Fixed legacy auth #105
* uvloop added to test suite #106
* Fixed bug with unicode in json field #107 (Thanks @methane)
0.0.8 (2016-08-24)
^^^^^^^^^^^^^^^^^^
* Default min pool size reduced to 1 #80 (Thanks @Drizzt1991)
* Update to PyMySQL 0.7.5 #89
* Fixed connection cancellation in process of executing a query #79 (Thanks @Drizzt1991)
0.0.7 (2016-01-27)
^^^^^^^^^^^^^^^^^^
* Fix for multiple results issue, ported from pymysql #52
* Fixed useless warning with no_delay option #55
* Added async/await support for Engine, SAConnection, Transaction #57
* pool.release returns future so we can wait on it in __aexit__ #60
* Update to PyMySQL 0.6.7
0.0.6 (2015-12-11)
^^^^^^^^^^^^^^^^^^
* Fixed bug with SA rollback (Thanks @khlyestovillarion!)
* Fixed issue with default no_delay option (Thanks @khlyestovillarion!)
0.0.5 (2015-10-28)
^^^^^^^^^^^^^^^^^^
* no_delay option is deprecated and True by default
* Add Cursor.mogrify() method
* Support for "LOAD LOCAL INFILE" query.
* Check connection inside pool, in case of timeout drop it, fixes #25
* Add support of python 3.5 features to pool, connection and cursor
0.0.4 (2015-05-23)
^^^^^^^^^^^^^^^^^^
* Allow to call connection.wait_closed twice.
* Fixed sqlalchemy 1.0.0 support.
* Fix #11: Rename Connection.wait_closed() to .ensure_closed()
* Raise ResourceWarning on non-closed Connection
* Rename Connection.connect to _connect
0.0.3 (2015-03-10)
^^^^^^^^^^^^^^^^^^
* Added support for PyMySQL up to 0.6.6.
* Ported improvements from PyMySQL.
* Added basic documentation.
* Fixed and added more examples.
0.0.2 (2015-02-17)
^^^^^^^^^^^^^^^^^^
* Added MANIFEST.in.
0.0.1 (2015-02-17)
^^^^^^^^^^^^^^^^^^
* Initial release.
* Implemented plain connections: connect, Connection, Cursor.
* Implemented database pools.
* Ported sqlalchemy optional support.
Raw data
{
"_id": null,
"home_page": "https://github.com/aio-libs/aiomysql",
"name": "aiomysql",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": "",
"keywords": "mysql,mariadb,asyncio,aiomysql",
"author": "Nikolay Novik",
"author_email": "nickolainovik@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/67/76/2c5b55e4406a1957ffdfd933a94c2517455291c97d2b81cec6813754791a/aiomysql-0.2.0.tar.gz",
"platform": "POSIX",
"description": "aiomysql\n========\n.. image:: https://github.com/aio-libs/aiomysql/actions/workflows/ci-cd.yml/badge.svg?branch=master\n :target: https://github.com/aio-libs/aiomysql/actions/workflows/ci-cd.yml\n.. image:: https://codecov.io/gh/aio-libs/aiomysql/branch/master/graph/badge.svg\n :target: https://codecov.io/gh/aio-libs/aiomysql\n :alt: Code coverage\n.. image:: https://badge.fury.io/py/aiomysql.svg\n :target: https://badge.fury.io/py/aiomysql\n :alt: Latest Version\n.. image:: https://readthedocs.org/projects/aiomysql/badge/?version=latest\n :target: https://aiomysql.readthedocs.io/\n :alt: Documentation Status\n.. image:: https://badges.gitter.im/Join%20Chat.svg\n :target: https://gitter.im/aio-libs/Lobby\n :alt: Chat on Gitter\n\n**aiomysql** is a \"driver\" for accessing a `MySQL` database\nfrom the asyncio_ (PEP-3156/tulip) framework. It depends on and reuses most\nparts of PyMySQL_ . *aiomysql* tries to be like awesome aiopg_ library and\npreserve same api, look and feel.\n\nInternally **aiomysql** is copy of PyMySQL, underlying io calls switched\nto async, basically ``yield from`` and ``asyncio.coroutine`` added in\nproper places)). `sqlalchemy` support ported from aiopg_.\n\n\nDocumentation\n-------------\nhttps://aiomysql.readthedocs.io/\n\nBasic Example\n-------------\n\n**aiomysql** based on PyMySQL_ , and provides same api, you just need\nto use ``await conn.f()`` or ``yield from conn.f()`` instead of calling\n``conn.f()`` for every method.\n\nProperties are unchanged, so ``conn.prop`` is correct as well as\n``conn.prop = val``.\n\n.. code:: python\n\n import asyncio\n import aiomysql\n\n\n async def test_example(loop):\n pool = await aiomysql.create_pool(host='127.0.0.1', port=3306,\n user='root', password='',\n db='mysql', loop=loop)\n async with pool.acquire() as conn:\n async with conn.cursor() as cur:\n await cur.execute(\"SELECT 42;\")\n print(cur.description)\n (r,) = await cur.fetchone()\n assert r == 42\n pool.close()\n await pool.wait_closed()\n\n\n loop = asyncio.get_event_loop()\n loop.run_until_complete(test_example(loop))\n\n\nExample of SQLAlchemy optional integration\n------------------------------------------\nSqlalchemy support has been ported from aiopg_ so api should be very familiar\nfor aiopg_ user.:\n\n.. code:: python\n\n import asyncio\n import sqlalchemy as sa\n\n from aiomysql.sa import create_engine\n\n\n metadata = sa.MetaData()\n\n tbl = sa.Table('tbl', metadata,\n sa.Column('id', sa.Integer, primary_key=True),\n sa.Column('val', sa.String(255)))\n\n\n async def go(loop):\n engine = await create_engine(user='root', db='test_pymysql',\n host='127.0.0.1', password='', loop=loop)\n async with engine.acquire() as conn:\n await conn.execute(tbl.insert().values(val='abc'))\n await conn.execute(tbl.insert().values(val='xyz'))\n\n async for row in conn.execute(tbl.select()):\n print(row.id, row.val)\n\n engine.close()\n await engine.wait_closed()\n\n\n loop = asyncio.get_event_loop()\n loop.run_until_complete(go(loop))\n\n\nRequirements\n------------\n\n* Python_ 3.7+\n* PyMySQL_\n\n\n.. _Python: https://www.python.org\n.. _asyncio: http://docs.python.org/3.5/library/asyncio.html\n.. _aiopg: https://github.com/aio-libs/aiopg\n.. _PyMySQL: https://github.com/PyMySQL/PyMySQL\n.. _Tornado-MySQL: https://github.com/PyMySQL/Tornado-MySQL\n\nChanges\n-------\n\n0.2.0 (2023-06-11)\n^^^^^^^^^^^^^^^^^^\n\n* Bump minimal SQLAlchemy version to 1.3 #815\n\n* Remove deprecated Pool.get #706\n\n* | Partially ported `PyMySQL#304 <https://github.com/PyMySQL/PyMySQL/pull/304>`_ #792\n | aiomysql now reraises the original exception during connect() if it's not `IOError`, `OSError` or `asyncio.TimeoutError`.\n | This was previously always raised as `OperationalError`.\n\n* Fix debug log level with sha256_password authentication #863\n\n* Modernized code with `pyupgrade <https://github.com/asottile/pyupgrade>`_ to Python 3.7+ syntax #930\n\n* Removed tests for EoL MariaDB versions 10.3, 10.7 and 10.8, added tests for MariaDB 10.9, 10.10, 10.11 #932\n\n0.1.1 (2022-05-08)\n^^^^^^^^^^^^^^^^^^\n\n* Fix SSL connection handshake charset not respecting client configuration #776\n\n0.1.0 (2022-04-11)\n^^^^^^^^^^^^^^^^^^\n\n* Don't send sys.argv[0] as program_name to MySQL server by default #620\n\n* Allow running process as anonymous uid #587\n\n* Fix timed out MySQL 8.0 connections raising InternalError rather than OperationalError #660\n\n* Fix timed out MySQL 8.0 connections being returned from Pool #660\n\n* Ensure connections are properly closed before raising an OperationalError when the server connection is lost #660\n\n* Ensure connections are properly closed before raising an InternalError when packet sequence numbers are out of sync #660\n\n* Unix sockets are now internally considered secure, allowing sha256_password and caching_sha2_password auth methods to be used #695\n\n* Test suite now also tests unix socket connections #696\n\n* Fix SSCursor raising InternalError when last result was not fully retrieved #635\n\n* Remove deprecated no_delay argument #702\n\n* Support PyMySQL up to version 1.0.2 #643\n\n* Bump minimal PyMySQL version to 1.0.0 #713\n\n* Align % formatting in Cursor.executemany() with Cursor.execute(), literal % now need to be doubled in Cursor.executemany() #714\n\n* Fixed unlimited Pool size not working, this is now working as documented by passing maxsize=0 to create_pool #119\n\n* Added Pool.closed property as present in aiopg #463\n\n* Fixed SQLAlchemy connection context iterator #410\n\n* Fix error packet handling for SSCursor #428\n\n* Required python version is now properly documented in python_requires instead of failing on setup.py execution #731\n\n* Add rsa extras_require depending on PyMySQL[rsa] #557\n\n* Migrate to PEP 517 build system #746\n\n* Self-reported `__version__` now returns version generated by `setuptools-scm` during build, otherwise `'unknown'` #748\n\n* Fix SSCursor raising query timeout error on wrong query #428\n\n\n0.0.22 (2021-11-14)\n^^^^^^^^^^^^^^^^^^^\n\n* Support python 3.10 #505\n\n\n0.0.21 (2020-11-26)\n^^^^^^^^^^^^^^^^^^^\n\n* Allow to use custom Cursor subclasses #374\n\n* Fill Connection class with actual client version #388\n\n* Fix legacy __aiter__ methods #403\n\n* Fix & update docs #418 #437\n\n* Ignore pyenv's .python-version file #424\n\n* Replace asyncio.streams.IncompleteReadError with asyncio.IncompleteReadError #460 #454\n\n* Add support for SQLAlchemy default parameters #455 #466\n\n* Update dependencies #485\n\n* Support Python 3.7 & 3.8 #493\n\n\n0.0.20 (2018-12-19)\n^^^^^^^^^^^^^^^^^^^\n\n* Fixed connect_timeout #360\n\n* Fixed support for SQLA executemany #324\n\n* Fix the python 3.7 compatibility #357\n\n* Fixed reuse connections when StreamReader has an exception #339\n\n* Fixes warning when inserting binary strings #326\n\n\n0.0.19 (2018-07-12)\n^^^^^^^^^^^^^^^^^^^\n\n* See v0.0.18\n\n\n0.0.18 (2018-07-09)\n^^^^^^^^^^^^^^^^^^^\n\n* Updated to support latest PyMySQL changes.\n\n* aiomysql now sends client connection info.\n\n* MySQL8+ Support including sha256_password and cached_sha2_password authentication plugins.\n\n* Default max packet length sent to the server is no longer 1.\n\n* Fixes issue where cursor.nextset can hang on query sets that raise errors.\n\n\n0.0.17 (2018-07-06)\n^^^^^^^^^^^^^^^^^^^\n\n* Pinned version of PyMySQL\n\n\n0.0.16 (2018-06-03)\n^^^^^^^^^^^^^^^^^^^\n\n* Added ability to execute precompiled sqlalchemy queries #294 (Thanks @vlanse)\n\n\n0.0.15 (2018-05-20)\n^^^^^^^^^^^^^^^^^^^\n\n* Fixed handling of user-defined types for sqlalchemy #290\n\n* Fix KeyError when server reports unknown collation #289\n\n\n0.0.14 (2018-04-22)\n^^^^^^^^^^^^^^^^^^^\n\n* Fixed SSL connection finalization #282\n\n\n0.0.13 (2018-04-19)\n^^^^^^^^^^^^^^^^^^^\n\n* Added SSL support #280 (Thanks @terrycain)\n\n* Fixed __all__ in aiomysql/__init__ #270 (Thanks @matianjun1)\n\n* Added docker fixtures #275 (Thanks @terrycain)\n\n\n0.0.12 (2018-01-18)\n^^^^^^^^^^^^^^^^^^^\n\n* Fixed support for SQLAlchemy 1.2.0\n\n* Fixed argument for cursor.execute in sa engine #239 (Thanks @NotSoSuper)\n\n\n0.0.11 (2017-12-06)\n^^^^^^^^^^^^^^^^^^^\n\n* Fixed README formatting on pypi\n\n\n0.0.10 (2017-12-06)\n^^^^^^^^^^^^^^^^^^^\n\n* Updated regular expressions to be compatible with pymysql #167 (Thanks @AlexLisovoy)\n\n* Added connection recycling in the pool #216\n\n\n0.0.9 (2016-09-14)\n^^^^^^^^^^^^^^^^^^\n\n* Fixed AttributeError in _request_authentication function #104 (Thanks @ttlttl)\n\n* Fixed legacy auth #105\n\n* uvloop added to test suite #106\n\n* Fixed bug with unicode in json field #107 (Thanks @methane)\n\n\n0.0.8 (2016-08-24)\n^^^^^^^^^^^^^^^^^^\n\n* Default min pool size reduced to 1 #80 (Thanks @Drizzt1991)\n\n* Update to PyMySQL 0.7.5 #89\n\n* Fixed connection cancellation in process of executing a query #79 (Thanks @Drizzt1991)\n\n\n0.0.7 (2016-01-27)\n^^^^^^^^^^^^^^^^^^\n\n* Fix for multiple results issue, ported from pymysql #52\n\n* Fixed useless warning with no_delay option #55\n\n* Added async/await support for Engine, SAConnection, Transaction #57\n\n* pool.release returns future so we can wait on it in __aexit__ #60\n\n* Update to PyMySQL 0.6.7\n\n\n0.0.6 (2015-12-11)\n^^^^^^^^^^^^^^^^^^\n\n* Fixed bug with SA rollback (Thanks @khlyestovillarion!)\n\n* Fixed issue with default no_delay option (Thanks @khlyestovillarion!)\n\n\n0.0.5 (2015-10-28)\n^^^^^^^^^^^^^^^^^^\n\n* no_delay option is deprecated and True by default\n\n* Add Cursor.mogrify() method\n\n* Support for \"LOAD LOCAL INFILE\" query.\n\n* Check connection inside pool, in case of timeout drop it, fixes #25\n\n* Add support of python 3.5 features to pool, connection and cursor\n\n\n0.0.4 (2015-05-23)\n^^^^^^^^^^^^^^^^^^\n\n* Allow to call connection.wait_closed twice.\n\n* Fixed sqlalchemy 1.0.0 support.\n\n* Fix #11: Rename Connection.wait_closed() to .ensure_closed()\n\n* Raise ResourceWarning on non-closed Connection\n\n* Rename Connection.connect to _connect\n\n\n0.0.3 (2015-03-10)\n^^^^^^^^^^^^^^^^^^\n\n* Added support for PyMySQL up to 0.6.6.\n\n* Ported improvements from PyMySQL.\n\n* Added basic documentation.\n\n* Fixed and added more examples.\n\n\n0.0.2 (2015-02-17)\n^^^^^^^^^^^^^^^^^^\n\n* Added MANIFEST.in.\n\n\n0.0.1 (2015-02-17)\n^^^^^^^^^^^^^^^^^^\n\n* Initial release.\n\n* Implemented plain connections: connect, Connection, Cursor.\n\n* Implemented database pools.\n\n* Ported sqlalchemy optional support.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "MySQL driver for asyncio.",
"version": "0.2.0",
"project_urls": {
"CI: GitHub": "https://github.com/aio-libs/aiomysql/actions",
"Docs: RTD": "https://aiomysql.readthedocs.io/",
"Download": "https://pypi.python.org/pypi/aiomysql",
"GitHub: discussions": "https://github.com/aio-libs/aiomysql/discussions",
"GitHub: issues": "https://github.com/aio-libs/aiomysql/issues",
"GitHub: repo": "https://github.com/aio-libs/aiomysql",
"Homepage": "https://github.com/aio-libs/aiomysql"
},
"split_keywords": [
"mysql",
"mariadb",
"asyncio",
"aiomysql"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "4287c982ee8b333c85b8ae16306387d703a1fcdfc81a2f3f15a24820ab1a512d",
"md5": "677da8788742d34daa5e34512ef01442",
"sha256": "b7c26da0daf23a5ec5e0b133c03d20657276e4eae9b73e040b72787f6f6ade0a"
},
"downloads": -1,
"filename": "aiomysql-0.2.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "677da8788742d34daa5e34512ef01442",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 44215,
"upload_time": "2023-06-11T19:57:51",
"upload_time_iso_8601": "2023-06-11T19:57:51.090120Z",
"url": "https://files.pythonhosted.org/packages/42/87/c982ee8b333c85b8ae16306387d703a1fcdfc81a2f3f15a24820ab1a512d/aiomysql-0.2.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "67762c5b55e4406a1957ffdfd933a94c2517455291c97d2b81cec6813754791a",
"md5": "96198d120c1109f53bed9724b1182c86",
"sha256": "558b9c26d580d08b8c5fd1be23c5231ce3aeff2dadad989540fee740253deb67"
},
"downloads": -1,
"filename": "aiomysql-0.2.0.tar.gz",
"has_sig": false,
"md5_digest": "96198d120c1109f53bed9724b1182c86",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 114706,
"upload_time": "2023-06-11T19:57:53",
"upload_time_iso_8601": "2023-06-11T19:57:53.608492Z",
"url": "https://files.pythonhosted.org/packages/67/76/2c5b55e4406a1957ffdfd933a94c2517455291c97d2b81cec6813754791a/aiomysql-0.2.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-06-11 19:57:53",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "aio-libs",
"github_project": "aiomysql",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"lcname": "aiomysql"
}