Psycopg2 wrapper
Project description
PG-DB
PG-DB is simple Psycopg wrapper.
Usage
First create an DB object and initialise it with the application,
from pg_db import DB
db = DB('test', 'root', debug=True)
def set_user(name):
db.connect()
db.execute("INSERT INTO users VALUES('Wendys');", (name, ))
db.commit()
db.close()
set_user('xyz')
can select one row,
def get_user(id):
db.connect()
row = db.one("SELECT name FROM users WHERE id=%s", (id, ), as_dict=True)
db.close()
return row['name']
print(get_user(1))
can select all rows,
def get_users():
db.connect()
rows = db.all("SELECT name FROM users;")
db.close()
return rows
print(get_users())
Usage on Quart
First create a Quart wrapper file (db.py),
from functools import wraps
from pg_db import DB
from quart import flash, redirect, request, session, url_for # make_response
from quart_auth import current_user
class db(DB):
def wrapper(self, func):
@wraps(func)
async def wrapped(*args, **kwargs):
try:
self.connect(session['schema'] if 'schema' in session else 'public',
'QUART_AUTH' in request.cookies and await current_user.readonly)
return await func(*args, **kwargs)
except Exception as e:
self.rollback()
if self.debug:
raise e
await flash("db error -> " + str(e))
return redirect(url_for(request.endpoint))
# return await make_response("db error -> " + str(e), 500)
finally:
try:
self.close()
except:
pass
return wrapped
Then enable db object from db.py globally for a Quart app,
from json import dumps
from .db import db
app = Quart(__name__)
db = db(AppConfig.DB_NAME, AppConfig.DB_USER, AppConfig.DEBUG)
@app.route('/get_users')
@db.wrapper
async def get_users():
return dumps(db.all("SELECT name FROM users;"))
Usage on Flask
First create a Flask wrapper file (db.py),
from functools import wraps
from pg_db import DB
from flask import flash, redirect, request, session, url_for # make_response
from flask_login import current_user
class db(DB):
def wrapper(self, func):
@wraps(func)
def wrapped(*args, **kwargs):
try:
self.connect(session['schema'] if 'schema' in session else 'public',
current_user.is_authenticated and current_user.readonly)
return func(*args, **kwargs)
except Exception as e:
self.rollback()
if self.debug:
raise e
flash("db error -> " + str(e))
return redirect(url_for(request.endpoint))
# return make_response("db error -> " + str(e), 500)
finally:
try:
self.close()
except:
pass
return wrapped
Then enable db object from db.py globally for a Flask app,
from json import dumps
from .db import db
app = Flask(__name__)
db = db(AppConfig.DB_NAME, AppConfig.DB_USER, AppConfig.DEBUG)
@app.route('/get_users')
@db.wrapper
def get_users():
return dumps(db.all("SELECT name FROM users;"))
Contributing
PG-DB is developed on GitLab. You are very welcome to open issues or propose merge requests.
Help
This README is the best place to start, after that try opening an issue.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
pg-db-1.1.tar.gz
(15.5 kB
view hashes)
Built Distribution
pg_db-1.1-py3-none-any.whl
(15.6 kB
view hashes)