Metadata-Version: 2.0
Name: aioorm
Version: 0.0.4
Summary: a simple orm suport asyncio,fork of aiopeewee
Home-page: https://github.com/Python-Tools/aioorm
Author: hsz
Author-email: hsz1273327@gmail.com
License: Mozilla
Keywords: orm,asyncio,peewee
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Topic :: Documentation :: Sphinx
Requires-Dist: aiofiles
Requires-Dist: aiomysql
Requires-Dist: aiopg
Requires-Dist: aitertools
Requires-Dist: peewee
Provides-Extra: dev
Requires-Dist: recommonmark; extra == 'dev'
Requires-Dist: sphinx; extra == 'dev'
Requires-Dist: sphinxcontrib-napoleon; extra == 'dev'
Requires-Dist: wheel; extra == 'dev'
Provides-Extra: test
Requires-Dist: coverage; extra == 'test'
Requires-Dist: lxml; extra == 'test'
Requires-Dist: mypy; extra == 'test'
Requires-Dist: mypy-extensions; extra == 'test'


aioorm
===============================

version: 0.0.4

author: hsz

email: hsz1273327@gmail.com



--------------------------------------------

Asyncio interface for peewee_ modeled after torpeewee_


Feature
----------------------

* support mysql and postgresql
* database factory using database URL
* use peewee's fields
* ManyToManyField support
* Shortcuts support
* csv dump /load support

Install
--------------------------------

- ``python -m pip install aioorm``

Example: GRUD
-------------------------------

.. code:: python

    from aioorm import AioModel, AioMySQLDatabase
    from peewee import CharField, TextField, DateTimeField
    from peewee import ForeignKeyField, PrimaryKeyField


    db = AioMySQLDatabase('test', host='127.0.0.1', port=3306,
                         user='root', password='')


    class User(AioModel):
        username = CharField()

        class Meta:
            database = db


    class Blog(AioModel):
        user = ForeignKeyField(User)
        title = CharField(max_length=25)
        content = TextField(default='')
        pub_date = DateTimeField(null=True)
        pk = PrimaryKeyField()

        class Meta:
            database = db


    # create connection pool
    await db.connect(loop)

    # count
    await User.select().count()

    # async iteration on select query
    async for user in User.select():
        print(user)

    # fetch all records as a list from a query in one pass
    users = await User.select()

    # insert
    user = await User.create(username='kszucs')

    # modify
    user.username = 'krisztian'
    await user.save()

    # async iteration on blog set
    [b.title async for b in user.blog_set.order_by(Blog.title)]

    # close connection pool
    await db.close()

    # see more in the tests



Example: Many to many
-------------------------------

Note that `AioManyToManyField` must be used instead of `ManyToMany`.


.. code:: python

    from aioorm import AioManyToManyField


    class User(AioModel):
        username = CharField(unique=True)

        class Meta:
            database = db


    class Note(AioModel):
        text = TextField()
        users = AioManyToManyField(User)

        class Meta:
            database = db


    NoteUserThrough = Note.users.get_through_model()


    async for user in note.users:
        # do something with the users


Currently the only limitation I'm aware of immidiate setting of instance relation must be replaced with a method call:

.. code:: python

    # original, which is not supported
    charlie.notes = [n2, n3]

    # use instead
    await charlie.notes.set([n2, n3])


Serializing
-----------

Converting to dict requires the asyncified version of `model_to_dict`

.. code:: python

    from aioorm import model_to_dict

    serialized = await model_to_dict(user)

Dump to csv
-------------

tables can be dump to a csv file.


.. code:: python

    from aioorm.utils import aiodump_csv
    query = User.select().order_by(User_csv.id)
    await aiodump_csv(query,str(filepath))



Documentation
--------------------------------

`Documentation on Readthedocs <https://github.com/Python-Tools/aioorm>`_.



TODO
-----------------------------------
* async dataset support
* more test



Limitations
-----------
* untested transactions
* only support mysql and postgresql

.. _peewee: http://docs.peewee-orm.com/en/latest/
.. _torpeewee: https://github.com/snower/torpeewee
.. _aiopeewee: https://github.com/kszucs/aiopeewee


