Skip to main content

MySQL driver for asyncio.

Project description

https://github.com/aio-libs/aiomysql/actions/workflows/ci-cd.yml/badge.svg?branch=master Code coverage Latest Version Documentation Status 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.

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.:

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

Changes

To be included in 0.1.0 (unreleased)

  • 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.

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

aiomysql-0.1.0rc2.tar.gz (114.0 kB view details)

Uploaded Source

Built Distribution

aiomysql-0.1.0rc2-py3-none-any.whl (43.9 kB view details)

Uploaded Python 3

File details

Details for the file aiomysql-0.1.0rc2.tar.gz.

File metadata

  • Download URL: aiomysql-0.1.0rc2.tar.gz
  • Upload date:
  • Size: 114.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for aiomysql-0.1.0rc2.tar.gz
Algorithm Hash digest
SHA256 67f854459a48e449a66eef15b100295b10c6ffc6b2f0304a1eb560b041cc750b
MD5 c582e71d57643b6ea3f8a9c55bdec320
BLAKE2b-256 fc86e3e1d81d9ff138d3c3a0d6284ed77c4b33c5c62fa14036e729757754c347

See more details on using hashes here.

File details

Details for the file aiomysql-0.1.0rc2-py3-none-any.whl.

File metadata

  • Download URL: aiomysql-0.1.0rc2-py3-none-any.whl
  • Upload date:
  • Size: 43.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for aiomysql-0.1.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 a49142ae711bfbeb68b5b36fb8c1cbd77cc11e04d4fea6849ded72df66fe4222
MD5 72a44d0e0a00765cd46d87493603fabc
BLAKE2b-256 563d821662b05201c375f3056c6c65e2a449b8b9638e9dfaee3e4b29a4701553

See more details on using hashes here.

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