database.py 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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 = 'tfb-database'
  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. def get_world(self, wid):
  30. return self.db.executesql('SELECT * FROM World WHERE id = %s',
  31. placeholders=[wid], as_dict=True)[0]
  32. def update_world(self, wid, randomNumber):
  33. self.db.executesql('UPDATE World SET randomNumber=%s WHERE id=%s',
  34. placeholders=[randomNumber, wid])
  35. def get_fortunes(self, new_message):
  36. fortunes = self.db.executesql('SELECT * FROM Fortune', as_dict=True)
  37. fortunes.append(new_message)
  38. return sorted(fortunes, key=itemgetter('message'))
  39. def num_queries(queries):
  40. try:
  41. num = int(queries)
  42. return 1 if num < 1 else 500 if num > 500 else num
  43. except ValueError:
  44. return 1