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.5.tar.gz (55.0 kB view details)

Uploaded Source

Built Distribution

Tornado_MySQL-0.5-py2.py3-none-any.whl (64.7 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

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

File hashes

Hashes for Tornado-MySQL-0.5.tar.gz
Algorithm Hash digest
SHA256 0ef1aa021d3447af08d2f5e4568fc57dc59c7f60a50da86dc67883ab7a144e63
MD5 031ee612435136abe8954d8a8876506d
BLAKE2b-256 5ef4d7f58d44456e1877f66403930fa89cb06fc2ec7aa0a8c18dbf078faed051

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Tornado_MySQL-0.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f211ac194e6ff3c85beebf1ecd74372b338141de5a14564ea0e9506d8fcb90d9
MD5 d59571b7aa21564eb95f2f66b0503557
BLAKE2b-256 474fa4ecaff62fbb1c3ffb85511b70f667b45bcf49c51bfcc6341cb2008f2a9a

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