/salty-orm

A Python 3.x ORM implementing a subset of the Django ORM object model features, support for Sqlite and MySql.

Primary LanguagePythonMIT LicenseMIT

Salty-ORM

A Python 3.x ORM implementing a subset of the Django ORM object model features, supports Sqlite and MySql.

The purpose of this ORM is to replicate a good portion of Django's ORM, but not have a Django dependency.

This ORM was written to make it easy to write python command line utilities that perform maintenance and queries on a Django backend database.

The Salty-ORM is very similar to Django's ORM, including supporting queries using a Q object similar to Django's ORM.

Records can be changed and saved, new records can be created and inserted as well.

Has support for handling and setting values for a 'created' and 'modified' datetime field if they exist in a table.

Examples

Connect to a MySQL Database

dbconn = MySQLDBConnection()

dbconn.db_connect(user='tester', password='****', database='test_db', host='xx.xx.xx.xx')

Simple Query

results = TestModel(dbconn).objects.filter(status=1).order_by('categories')

Query, Update and Save

record = TestModel(dbconn).objects.get(id=1)

record.category = 'new'

record.save(cleaned=True)

Limit Fields Returned

results = TestModel(dbconn).objects.distinct().values_list('id', 'tariffs').filter(Q('subject', QOper.O_LIKE, 'zap*') & Q('subject', QOper.O_LIKE, 'zoo*') | Q('subject', QOper.O_IS, 'abc') & Q('subject', QOper.O_IS, '123')).order_by('modified').all())

Return all records with an ID value greater than 5 and exclude ID = 10

results = TestModel(dbconn).objects.values_list('id', 'modified', 'name').get(~Q('id', QOper.O_EQUAL, 10) & Q('id', QOper.O_GT_EQUAL, 5))

Printing SQL Statement

sql_text = TestModel(dbconn).objects.filter(active=1).order_by('a_field').to_sql()

Counts

total = TestModel(dbconn).objects.count()

Limit Records Returned

results = TestModel(dbconn).objects.all().limit(10)

Note: The Salty-ORM Get() method does not support Django's interpreted name parts. IE: id__eq=1

See examples/models.py for an example of a Salty-ORM model.

The utilities/clone_django_models.py program can be used to scan a Django project and build Salty-ORM compatible models.

Contributions and questions are welcome.