Skip to main content

pymysql-based database connection pool

Project description

PyMySQLPool

build status codecov pip version license

PyMySQLPool is a pymysql-based database connection pool, simple and lightweight.

Table of content

Features

  • Maintain a minimum number of connection pools by default.
  • If a number of unuse connections less than zero, dynamically add connections to pool until the current number of inuse connections equal maximum of the pool.
  • Release the idle connections in regular until a number of unuse connections equal minimum of the pool.
  • Support auto-commit mode.
  • Support for ping check to get healthy connections.

Requirements

  • Python
    • CPython : >= 3.4
  • MySQL Server -- one of the following:
    • MySQL >= 5.5
    • MariaDB >= 5.5
  • PyMySQL: >= 0.9.2

Installation

Package is uploaded on PyPI

You can install with pip

$ pip install pymysql-pooling

Example

Make use of a simple table (Example in MySQL doc)

mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20),
    -> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);

mysql> INSERT INTO pet
    -> VALUES ("Puffball", "Diane", "hamster", "f", "1999-03-30", NULL);
from pymysqlpool.pool import Pool


# Note: you can also add any parameters relates to `pymysql.connections.Connection` object
pool = Pool(host=HOST, port=PORT, user=USER, password=PASSWORD, db=DB)
pool.init()

connection = pool.get_conn()
cur = connection.cursor()
cur.execute('SELECT * FROM `pet` WHERE `name`=%s', args=("Puffball", ))
print(cur.fetchone())

pool.release(connection)

This example will print:

('Puffball', 'Diane', 'hamster', 'f', datetime.date(1999, 3, 30), None)

Support autocommit mode, as following:

pool = Pool(host=HOST, port=PORT, user=USER, password=PASSWORD, db=DB, autocommit=True)

That's all.

Roadmap

  • Connection Pool
  • Dynamically Create
  • Dynamically Release
  • Monitor Web Interface

Resources

License

PyMySQLPool is released under the MIT License. See LICENSE for more information.

Contributing

Thank you for your interest in the contribution of PyMySQLPool, your help and contribution is very valuable.

You can submit an issue and pull requests, please submit an issue before submitting pull requests.

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

pymysql-pooling-codingman-1.0.6.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pymysql_pooling_codingman-1.0.6-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

Details for the file pymysql-pooling-codingman-1.0.6.tar.gz.

File metadata

  • Download URL: pymysql-pooling-codingman-1.0.6.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.2

File hashes

Hashes for pymysql-pooling-codingman-1.0.6.tar.gz
Algorithm Hash digest
SHA256 b05cc0323db873349d11aea149b31a579787cdf01b1447e6fd3c64f2a5b8184f
MD5 fbce54034956bc06f70edbb5a004e346
BLAKE2b-256 f18dd717f250659e4c7d4b0d768a13a3c49099ccd20e21f3ff8ccd9a4779b384

See more details on using hashes here.

File details

Details for the file pymysql_pooling_codingman-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: pymysql_pooling_codingman-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 7.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.2

File hashes

Hashes for pymysql_pooling_codingman-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 0522ccf423dbb371e3376d8e56a9d1077e61a07d63cb0add1e04b3c7030a6070
MD5 8a37b5662f851ba9bf96d1c57f8af4a0
BLAKE2b-256 bb01b858cd23b6a674df92235fe4f82ba2343667b0050bf415ce816bf0b03471

See more details on using hashes here.

Supported by

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