Files
@ cbdd583f1e58
Branch filter:
Location: kallithea/rhodecode/model/meta.py - annotation
cbdd583f1e58
1.8 KiB
text/x-python
reverted copy of cached instance:
CPython
changelog
total_time 39.7253162861
average on req 0.993132907152
changesets
total_time 42.5156304836
average on req 0.425156304836
Total: 546 MB
changelog
total_time 35.5851216316
average on req 0.889628040791
changesets
total_time 30.3608012199
average on req 0.303608012199
Total: 475 MB
CPython
changelog
total_time 39.7253162861
average on req 0.993132907152
changesets
total_time 42.5156304836
average on req 0.425156304836
Total: 546 MB
changelog
total_time 35.5851216316
average on req 0.889628040791
changesets
total_time 30.3608012199
average on req 0.303608012199
Total: 475 MB
1e757ac98988 1e757ac98988 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 1e757ac98988 5d676b6ab71c 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 1e757ac98988 aa7e45ad0cea 5d676b6ab71c 5d676b6ab71c 6832ef664673 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 6832ef664673 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 6832ef664673 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 5d676b6ab71c 1e757ac98988 5d676b6ab71c 1e757ac98988 1e757ac98988 1e757ac98988 | """SQLAlchemy Metadata and Session object"""
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import scoped_session, sessionmaker, class_mapper
from beaker import cache
from rhodecode.model import caching_query
# Beaker CacheManager. A home base for cache configurations.
cache_manager = cache.CacheManager()
__all__ = ['Base', 'Session']
#
# SQLAlchemy session manager. Updated by model.init_model()
#
Session = scoped_session(
sessionmaker(
query_cls=caching_query.query_callable(cache_manager)
)
)
class BaseModel(object):
"""Base Model for all classess
"""
@classmethod
def _get_keys(cls):
"""return column names for this model """
return class_mapper(cls).c.keys()
def get_dict(self):
"""return dict with keys and values corresponding
to this model data """
d = {}
for k in self._get_keys():
d[k] = getattr(self, k)
return d
def get_appstruct(self):
"""return list with keys and values tupples corresponding
to this model data """
l = []
for k in self._get_keys():
l.append((k, getattr(self, k),))
return l
def populate_obj(self, populate_dict):
"""populate model with data from given populate_dict"""
for k in self._get_keys():
if k in populate_dict:
setattr(self, k, populate_dict[k])
@classmethod
def query(cls):
return Session.query(cls)
@classmethod
def get(cls, id_):
return Session.query(cls).get(id_)
# The declarative Base
Base = declarative_base(cls=BaseModel)
#to use cache use this in query
#.options(FromCache("sqlalchemy_cache_type", "cachekey"))
|