Skip to main content

Pure Python MySQL Driver for Tornado

Project description

https://travis-ci.org/PyMySQL/Tornado-MySQL.svg?branch=tornado

This package contains a fork of PyMySQL supporting Tornado.

Example

example

#!/usr/bin/env python
from __future__ import print_function

from tornado import ioloop, gen
import tornado_mysql

@gen.coroutine
def main():
    conn = yield tornado_mysql.connect(host='127.0.0.1', port=3306, user='root', passwd='', db='mysql')
    cur = conn.cursor()
    yield cur.execute("SELECT Host,User FROM user")
    print(cur.description)
    for row in cur:
       print(row)
    cur.close()
    conn.close()

ioloop.IOLoop.current().run_sync(main)

example_pool

#!/usr/bin/env python
from __future__ import print_function

from tornado import ioloop, gen
from tornado_mysql import pools


pools.DEBUG = True


POOL = pools.Pool(
    dict(host='127.0.0.1', port=3306, user='root', passwd='', db='mysql'),
    max_idle_connections=1,
    max_recycle_sec=3)


@gen.coroutine
def worker(n):
    for i in range(10):
        t = 1
        print(n, "sleeping", t, "seconds")
        cur = yield POOL.execute("SELECT SLEEP(%s)", (t,))
        print(n, cur.fetchall())


@gen.coroutine
def main():
    workers = [worker(i) for i in range(10)]
    yield workers


ioloop.IOLoop.current().run_sync(main)
print(POOL._opened_conns)

Requirements

  • Python – one of the following:

  • MySQL Server – one of the following:

Installation

The last stable release is available on PyPI and can be installed with pip:

$ pip install Tornado-MySQL

Test Suite

If you would like to run the test suite, first copy the file .travis.databases.json to tornado_mysql/tests/databases.json and edit the new file to match your MySQL configuration:

$ cp .travis.databases.json tornado_mysql/tests/databases.json
$ $EDITOR tornado_mysql/tests/databases.json

To run all the tests, execute the script runtests.py:

$ python runtests.py

A tox.ini file is also provided for conveniently running tests on multiple Python versions:

$ tox

Resources

DB-API 2.0: http://www.python.org/dev/peps/pep-0249

MySQL Reference Manuals: http://dev.mysql.com/doc/

MySQL client/server protocol: http://dev.mysql.com/doc/internals/en/client-server-protocol.html

PyMySQL mailing list: https://groups.google.com/forum/#!forum/pymysql-users

License

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

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

Tornado-MySQL-0.3.tar.gz (56.3 kB view details)

Uploaded Source

Built Distribution

Tornado_MySQL-0.3-py2.py3-none-any.whl (66.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file Tornado-MySQL-0.3.tar.gz.

File metadata

  • Download URL: Tornado-MySQL-0.3.tar.gz
  • Upload date:
  • Size: 56.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Tornado-MySQL-0.3.tar.gz
Algorithm Hash digest
SHA256 e69e87008c1d28162cfda0e54739191c9d7a3c43e358b51b3bd2751bb9c43f25
MD5 102c59c66ddac7537143dc7310b003f9
BLAKE2b-256 affd4ef6091f900f621c0c06521c1ed5a7c1ae825ace59dba7128338133b480d

See more details on using hashes here.

File details

Details for the file Tornado_MySQL-0.3-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for Tornado_MySQL-0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 252ea3ca9697dcce3fed99cd6db283ad3b0383b9454c9b8a395f12d703fdc519
MD5 cad22cd8ed99181ca0fa2a21de69afd2
BLAKE2b-256 ed92c20482b1130788f711b5c5ac80f21d5a55208836dbf2f9ad0e894fab5c33

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