Simple MySQL query builder and profiler
Project description
Following the rule simple easy, complex possibe, MySql Simple Query Builder provides API for basic queries, nested transactions, and aid in complex query building and profiling.
DML
SELECT
The following modes are supported:
counting:
db.count('customer', {'storeId' : 1}) # 326L
single row’s field value:
db.one(('firstName',), 'customer', {'customerId' : 1}) # u'MARY'
single row’s fields value dictionary:
db.one(('firstName', 'lastName'), 'customer', {'customerId' : 1}) # {'firstName': u'MARY', 'lastName': u'SMITH'}
multiple rows’ single field value projection:
db.select(('firstName',), 'customer', {'customerId' : (1, 2)}) # (u'MARY', u'PATRICIA')
multiple rows’ fields value tuple:
db.select(('firstName', 'lastName'), 'customer', {'customerId' : (1, 2)}) # ({'firstName': u'MARY', 'lastName': u'SMITH'}, {'firstName': u'PATRICIA', 'lastName': u'JOHNSON'})
WHERE condition is a conjunction. Supported arguments are ones support by underlying library, MySQLdb, and its escaping functionality:
None,
int (long, float, Decimal),
datetime (date),
unicode (str),
tuple of int (list of int),
Besides supported are ORDER BY and LIMIT.
Complex query
sql = '''
SELECT c.first_name `firstName`, c.last_name `lastName`
FROM customer c
JOIN store s USING(store_id)
JOIN staff t ON s.manager_staff_id = t.staff_id
{where} AND t.email LIKE {like}
'''
db.query(
# escape % as it is used by MySQLdb
sql.replace('{like}', db.quote('%%@sakilastaff.com')),
{'c.active' : True},
limit = 1
).fetchall()
# ({'firstName': u'MARY', 'lastName': u'SMITH'},)
Or the same with cursor:
sql = '''
SELECT c.first_name `firstName`, c.last_name `lastName`
FROM customer c
JOIN store s USING(store_id)
JOIN staff t ON s.manager_staff_id = t.staff_id
WHERE c.active = :active AND t.email LIKE :email
LIMIT 0, 1
'''
cursor = db.cursor(dict)
cursor.execute(sql, {'active' : True, 'email' : '%@sakilastaff.com'})
cursor.fetchall()
# ({'firstName': u'MARY', 'lastName': u'SMITH'},)
INSERT
Supports single row insert.
UPDATE
Supports one table at a time. Has the same WHERE features as decribed above.
DELETE
Supports one table at a time. Has the same WHERE features as decribed above.
Test
Test suite is built against Sakila test database available at MySQL site. Besides allowing further refacotring, it provides examples of usage.
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
File details
Details for the file MysqlSimpleQueryBuilder-0.2.6.zip
.
File metadata
- Download URL: MysqlSimpleQueryBuilder-0.2.6.zip
- Upload date:
- Size: 13.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 67d7d14afebf160d4ccbb999516cb666a18d723c3d13e992502ce173a0b80370 |
|
MD5 | 670dcab744d488107d3cd8c74169eeff |
|
BLAKE2b-256 | 30d39b365a1737ba067de87f7a03a6784eccd47f2828bcaeb62942cfc3fab2f5 |