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.0a5.tar.gz (21.2 kB view details)

Uploaded Source

Built Distribution

quma-0.1.0a5-py3-none-any.whl (27.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: quma-0.1.0a5.tar.gz
  • Upload date:
  • Size: 21.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.6.4+

File hashes

Hashes for quma-0.1.0a5.tar.gz
Algorithm Hash digest
SHA256 cc35a23ee44099599b1d173b87102841e27a599716ffde448744fb141702a2e9
MD5 0d662b18b5a4ca99cf65c24b86b21bcc
BLAKE2b-256 97c35076947c061d37c0b7343e9430c09bf00dfb684e13f2f77ae10b77f95ce0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: quma-0.1.0a5-py3-none-any.whl
  • Upload date:
  • Size: 27.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.6.4+

File hashes

Hashes for quma-0.1.0a5-py3-none-any.whl
Algorithm Hash digest
SHA256 3320e46fbab5ab0e94c5656f92fe6e4468118cc7190234524b2a0d71555408c0
MD5 b0a81d2c58f00c75f1891a15890e4322
BLAKE2b-256 57579b19079d29220b455f2bda591e649468009a32d57bc5f53110e2bb27bb8a

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