扫码登录,获取cookies

This commit is contained in:
2026-03-09 16:10:29 +08:00
parent 754e720ba7
commit 8229208165
7775 changed files with 1150053 additions and 208 deletions

View File

@@ -0,0 +1 @@
pip

View File

@@ -0,0 +1,19 @@
Copyright (c) 2010, 2013 PyMySQL contributors
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

View File

@@ -0,0 +1,447 @@
Metadata-Version: 2.1
Name: aiomysql
Version: 0.2.0
Summary: MySQL driver for asyncio.
Home-page: https://github.com/aio-libs/aiomysql
Download-URL: https://pypi.python.org/pypi/aiomysql
Author: Nikolay Novik
Author-email: nickolainovik@gmail.com
License: MIT
Project-URL: CI: GitHub, https://github.com/aio-libs/aiomysql/actions
Project-URL: Docs: RTD, https://aiomysql.readthedocs.io/
Project-URL: GitHub: repo, https://github.com/aio-libs/aiomysql
Project-URL: GitHub: issues, https://github.com/aio-libs/aiomysql/issues
Project-URL: GitHub: discussions, https://github.com/aio-libs/aiomysql/discussions
Keywords: mysql,mariadb,asyncio,aiomysql
Platform: POSIX
Classifier: License :: OSI Approved :: MIT License
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Operating System :: POSIX
Classifier: Environment :: Web Environment
Classifier: Development Status :: 3 - Alpha
Classifier: Topic :: Database
Classifier: Topic :: Database :: Front-Ends
Classifier: Framework :: AsyncIO
Requires-Python: >=3.7
Description-Content-Type: text/x-rst
License-File: LICENSE
Requires-Dist: PyMySQL (>=1.0)
Provides-Extra: rsa
Requires-Dist: PyMySQL[rsa] (>=1.0) ; extra == 'rsa'
Provides-Extra: sa
Requires-Dist: sqlalchemy (<1.4,>=1.3) ; extra == 'sa'
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.

View File

@@ -0,0 +1,37 @@
aiomysql-0.2.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
aiomysql-0.2.0.dist-info/LICENSE,sha256=MUEg3GXwgA9ziksxQAx27hTezR--d86cNUCkIbhup7Y,1070
aiomysql-0.2.0.dist-info/METADATA,sha256=jWCXugdJETo0w5g8Ly1-MPasuzf1-yixv3UPOw2a-dM,11968
aiomysql-0.2.0.dist-info/RECORD,,
aiomysql-0.2.0.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
aiomysql-0.2.0.dist-info/WHEEL,sha256=pkctZYzUS4AYVn6dJ-7367OJZivF2e8RA9b_ZBjif18,92
aiomysql-0.2.0.dist-info/top_level.txt,sha256=xs48LuKLNdJ2q3dsQcQtWUO9OsoCyMfbO_eQN7H3Fx4,9
aiomysql/.gitignore,sha256=9iHLtD_a6XKwfLNu10aPpI21-LYbwQG8S04DJ8PJW0o,17
aiomysql/__init__.py,sha256=IveEz5O-p8iLaEvUkmsLSNM25rOmKxuz4J7gUS8lVGw,2219
aiomysql/__pycache__/__init__.cpython-311.pyc,,
aiomysql/__pycache__/_scm_version.cpython-311.pyc,,
aiomysql/__pycache__/_version.cpython-311.pyc,,
aiomysql/__pycache__/connection.cpython-311.pyc,,
aiomysql/__pycache__/cursors.cpython-311.pyc,,
aiomysql/__pycache__/log.cpython-311.pyc,,
aiomysql/__pycache__/pool.cpython-311.pyc,,
aiomysql/__pycache__/utils.cpython-311.pyc,,
aiomysql/_scm_version.py,sha256=g0RU_Fiae76hPEUjU6lGnapa9IZoqGcB4oFcTnsoMbM,142
aiomysql/_scm_version.pyi,sha256=UwfFHrNq6VmZE8d1qRk9xsPfI5mBt11FPQUOBaMqlgk,125
aiomysql/_version.py,sha256=oMV4N1zz2Tam94pUAwxioFYLw0m9vnWJ46dKTJ6Pbqc,87
aiomysql/connection.py,sha256=rL6QNh0SHZvoQJTFMx-9u6inf25meY7sFdlUiL2Y86Q,52372
aiomysql/cursors.py,sha256=zoI5y7x1I6ObHEI1WhVL4p_eYn86LWlI1exKh8MyOs8,23475
aiomysql/log.py,sha256=jHJAltl-4UrBpOocVgMUf_f_moD1Yuq1yoEEYUZ6iko,122
aiomysql/pool.py,sha256=6rMRcOa0xvKaiN8a36mw8uVdUqqsZGMQFs_2UADrqLM,8402
aiomysql/sa/__init__.py,sha256=QAgff9W0fgSgyqtdTVA8xG5LAqXE5UcJss_ndyZsbHQ,561
aiomysql/sa/__pycache__/__init__.cpython-311.pyc,,
aiomysql/sa/__pycache__/connection.cpython-311.pyc,,
aiomysql/sa/__pycache__/engine.cpython-311.pyc,,
aiomysql/sa/__pycache__/exc.cpython-311.pyc,,
aiomysql/sa/__pycache__/result.cpython-311.pyc,,
aiomysql/sa/__pycache__/transaction.cpython-311.pyc,,
aiomysql/sa/connection.py,sha256=enfW3Jsznp0ICpGQtmPrl91iYvJPf6zb7XlEnWE2aBE,14895
aiomysql/sa/engine.py,sha256=4ZMlIjWbuwzUach_yV_1j2faRG1PiWTb-WnnKABr7xA,6916
aiomysql/sa/exc.py,sha256=IyQoJXnyWc298EugnlgBdDcWtEkmwHmpmCDZltitSmk,777
aiomysql/sa/result.py,sha256=q88C-F0B68ABjCOeFWgOpQ8DKGBoT4tL5e-SxVcsK6g,15068
aiomysql/sa/transaction.py,sha256=yo7wx499DNkrcyzM6cGCcPvKZmOhwAStX-kMQ0RdNbE,4912
aiomysql/utils.py,sha256=ZgJPntELXtlFez-gkzkNzYM4IeuKKthP5Qu2Bhf25T8,4486

View File

@@ -0,0 +1,5 @@
Wheel-Version: 1.0
Generator: bdist_wheel (0.40.0)
Root-Is-Purelib: true
Tag: py3-none-any

View File

@@ -0,0 +1 @@
aiomysql