raw_controller.php 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <?php
  2. class RawController extends AppController
  3. {
  4. protected $pdo;
  5. protected function before_filter()
  6. {
  7. View::select(null, null);
  8. header('Content-type: application/json');
  9. $this->pdo = new PDO('mysql:host=tfb-database;dbname=hello_world', 'benchmarkdbuser', 'benchmarkdbpass', array(
  10. PDO::ATTR_PERSISTENT => true
  11. ));
  12. }
  13. public function index()
  14. {
  15. $res = $this->pdo->prepare('SELECT randomNumber FROM World WHERE id = ?');
  16. $id = mt_rand(1, 10000);
  17. $res->execute(array($id));
  18. echo json_encode(['id' => $id, 'randomNumber' => $res->fetchColumn()]);
  19. }
  20. public function queries($count = 1)
  21. {
  22. //$queries = ($queries < 1) ? 1 : (($queries > 500) ? 500 : $queries);
  23. $count = is_numeric($count) ? min(max($count, 1), 500) : 1;
  24. $res = $this->pdo->prepare('SELECT randomNumber FROM World WHERE id = ?');
  25. $worlds = [];
  26. for ($i = 0; $i < $count; ++$i) {
  27. $id = mt_rand(1, 10000);
  28. $res->execute(array($id));
  29. $worlds[] = array('id' => $id, 'randomNumber' => $res->fetchColumn());
  30. }
  31. echo json_encode($worlds);
  32. }
  33. public function update($count = 1)
  34. {
  35. $count = is_numeric($count) ? min(max($count, 1), 500) : 1;
  36. $worlds = [];
  37. $sth = $this->pdo->prepare('SELECT * FROM World WHERE id = ?');
  38. $updateSth = $this->pdo->prepare('UPDATE World SET randomNumber = ? WHERE id = ?');
  39. for ($i = 0; $i < $count; ++$i) {
  40. $id = mt_rand(1, 10000);
  41. $randomNumber = mt_rand(1, 10000);
  42. $sth->execute(array($id));
  43. $row = ['id' => $id, 'randomNumber' => $updateSth->fetchColumn()];
  44. $row['randomNumber'] = $randomNumber;
  45. $updateSth->execute([$randomNumber, $id]);
  46. $worlds[] = $row;
  47. }
  48. echo json_encode($worlds);
  49. }
  50. }