database.py 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. # -*- coding: utf-8 -*-
  2. import os
  3. from operator import itemgetter
  4. from gluon.storage import Storage
  5. from gluon.dal import DAL, Field, Row
  6. DBHOST = os.environ.get('DBHOST', 'localhost')
  7. DATABASE_URI = 'mysql://benchmarkdbuser:benchmarkdbpass@%s:3306/hello_world' % DBHOST
  8. class Dal(object):
  9. def __init__(self, table=None, pool_size=8):
  10. self.db = DAL(DATABASE_URI, migrate_enabled=False, pool_size=pool_size)
  11. if table == 'World':
  12. self.db.define_table('World', Field('randomNumber', 'integer'))
  13. elif table == 'Fortune':
  14. self.db.define_table('Fortune', Field('message'))
  15. def get_world(self, wid):
  16. # Setting `cacheable=True` improves performance by foregoing the creation
  17. # of some non-essential attributes. It does *not* actually cache the
  18. # database results (it simply produces a Rows object that *could be* cached).
  19. return self.db(self.db.World.id == wid).select(cacheable=True)[0].as_dict()
  20. def update_world(self, wid, randomNumber):
  21. self.db(self.db.World.id == wid).update(randomNumber=randomNumber)
  22. def get_fortunes(self, new_message):
  23. fortunes = self.db(self.db.Fortune).select(cacheable=True)
  24. fortunes.records.append(Row(new_message))
  25. return fortunes.sort(itemgetter('message'))
  26. class RawDal(Dal):
  27. def __init__(self):
  28. super(RawDal, self).__init__()
  29. self.world_updates = []
  30. def get_world(self, wid):
  31. return self.db.executesql('SELECT * FROM World WHERE id = %s',
  32. placeholders=[wid], as_dict=True)[0]
  33. def update_world(self, wid, randomNumber):
  34. self.world_updates.extend([randomNumber, wid])
  35. def flush_world_updates(self):
  36. query = ';'.join('UPDATE World SET randomNumber=%s WHERE id=%s'
  37. for _ in xrange(len(self.world_updates) / 2))
  38. self.db.executesql(query, placeholders=self.world_updates)
  39. def get_fortunes(self, new_message):
  40. fortunes = self.db.executesql('SELECT * FROM Fortune', as_dict=True)
  41. fortunes.append(new_message)
  42. return sorted(fortunes, key=itemgetter('message'))
  43. def num_queries(queries):
  44. try:
  45. num = int(queries)
  46. return 1 if num < 1 else 500 if num > 500 else num
  47. except ValueError:
  48. return 1