Skip to main content

A SQLAlchemy wrapper that stays out of your way

Project description

version Build status of master branch

For when you just want to write SQL

Rowhouse is a SQLAlchemy wrapper that attempts to strike a happy medium between using raw database bindings like psycopg2 and using the full SQLAlchemy API.

Use it when:

  • You don’t want to mess with connections, cursors, sessions, etc

  • You don’t need or want an ORM or repository

  • You don’t want to look up SQLAlchemy’s expression language every time you need a non-trivial query

  • You just want to write some SQL, and work with plain old dicts and lists

  • You want some convenient helper functions for common operations

Install

pip install rowhouse

Basic Usage

from rowhouse import Connection
db = Connnection('postgresql://localhost/mydatabase')

# Run some SQL
row = db.fetchone('SELECT * FROM users WHERE username = %s', ('mreynolds',))
print('Name = ' + row['fullname'])

for row in db.fetchiter('SELECT * FROM users'):
    print('User: ' + row['fullname'])

db.begin()
db.execute('CREATE TABLE groups (...)')
db.execute('INSERT INTO groups VALUES (%s, %s)', ('firefly', 'mreynolds'))
db.commit()

# Some convenient helpers
with db.transaction():
    row = db.findone('users', username='mreynolds')
    db.update('users', {
        'role': 'captain'
    }, id=row['id'])
    newrow = db.insert('users', {
        'fullname': 'Zoe Washburne',
        'username': 'zwashburne',
        'role': 'first_mate'
    })

To Do

  • [x] Implement find* methods

  • [x] Implement insert/update/delete/upsert methods

  • [x] Add tests and CI

  • [x] Add packaging and publish to pypi

  • [ ] More configurability - constructor, setters, etc

  • [ ] Simple model support - little more than classes with a Connection baked in and some convenience methods

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

rowhouse-1.0.3.tar.gz (3.1 kB view details)

Uploaded Source

File details

Details for the file rowhouse-1.0.3.tar.gz.

File metadata

  • Download URL: rowhouse-1.0.3.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for rowhouse-1.0.3.tar.gz
Algorithm Hash digest
SHA256 00ff798e0dd4be2607245b100120d72c310666dba14f8aad6437af8f8753766f
MD5 447c6033addf3374281008a4b8364a69
BLAKE2b-256 fd799667d9e1fe5d6536e56df2ff385494636f3b724bfb17b5353cbf882ffb55

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page