Skip to main content

A SQL/database library

Project description

master Travis CI Status PyPi package version Documentation Status

quma is a small SQL database library for Python and PyPy version 3.5 and higher. It maps object methods to SQL script files and supports SQLite, PostgreSQL, MySQL and MariaDB.

Unlike ORMs, it allows to write SQL as it was intended and to use all features the DBMS provides. As it uses plain SQL files you can fully utilize your database editor or IDE to author your queries.

It also provides a simple connection pool.

Installation

pip install quma

Quick Start

The full documentation is available at https://quma.readthedocs.io

Given a directory with some SQL scripts e. g.:

/path/to/sql/scripts
├── users
│    ├── all.sql
│    └── remove.sql
└── get_admin.sql

You can access these scripts after connecting to the database:

from quma import Database

db = Database('sqlite:///:memory:', '/path/to/sql/scripts')

db.execute('CREATE TABLE users ...')

with db.cursor as cur:
    all_users = cur.users.all()

    for user in all_users:
        print(user['name'])

    cur.users.remove(id=user['id']).run()
    cur.commit()

    admin = cur.get_admin()

License

quma is released under the MIT license.

Copyright © 2018 ebene fünf GmbH. All rights reserved.

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

quma-0.1.0b1.tar.gz (21.7 kB view details)

Uploaded Source

Built Distribution

quma-0.1.0b1-py3-none-any.whl (28.2 kB view details)

Uploaded Python 3

File details

Details for the file quma-0.1.0b1.tar.gz.

File metadata

  • Download URL: quma-0.1.0b1.tar.gz
  • Upload date:
  • Size: 21.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.0 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.7.2

File hashes

Hashes for quma-0.1.0b1.tar.gz
Algorithm Hash digest
SHA256 1d139d4ed14e9e3ee88d5938305f98136bd3b7fd12ab9436bc8c9dc82cbc99a5
MD5 5a8079ad7b46e958a9deda221091bf2b
BLAKE2b-256 1439123752e7bc00e82bfe2fb0941b535b6db158217685d0cecd87d59e44c55e

See more details on using hashes here.

File details

Details for the file quma-0.1.0b1-py3-none-any.whl.

File metadata

  • Download URL: quma-0.1.0b1-py3-none-any.whl
  • Upload date:
  • Size: 28.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.0 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.7.2

File hashes

Hashes for quma-0.1.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 721ef373ca91da11de4cebe425bf80aa1fe52c11e3a06308f1560c668f2fe1d2
MD5 c8a6fa88ca21b155824956c1d6ab630e
BLAKE2b-256 afba0f0615b95af93a9601ea3e79fe8a868cb1f2ef62e86af9720e54834b2c34

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