UpdateResource.php 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. namespace Benchmark\Resources;
  3. use Hamlet\Database\Database;
  4. use Hamlet\Entities\JsonEntity;
  5. use Hamlet\Requests\Request;
  6. use Hamlet\Resources\WebResource;
  7. use Hamlet\Responses\OKResponse;
  8. use Hamlet\Responses\Response;
  9. class UpdateResource implements WebResource
  10. {
  11. private $database;
  12. public function __construct(Database $database)
  13. {
  14. $this->database = $database;
  15. }
  16. public function getResponse(Request $request): Response
  17. {
  18. $count = $request->getQueryParams()['queries'] ?? null;
  19. if ($count !== null && $count > 0) {
  20. $count = min($count, 500);
  21. } else {
  22. $count = 1;
  23. }
  24. $selectQuery = '
  25. SELECT id,
  26. randomNumber
  27. FROM World
  28. WHERE id = ?
  29. ';
  30. $selectProcedure = $this->database->prepare($selectQuery);
  31. $updateQuery = '
  32. UPDATE World
  33. SET randomNumber = ?
  34. WHERE id = ?
  35. ';
  36. $updateProcedure = $this->database->prepare($updateQuery);
  37. $payload = [];
  38. while ($count-- > 0) {
  39. $id = mt_rand(1, 10000);
  40. $randomNumber = mt_rand(1, 10000);
  41. $selectProcedure->bindInteger($id);
  42. $entry = $selectProcedure->fetchOne();
  43. $entry['randomNumber'] = $randomNumber;
  44. $updateProcedure->bindInteger($randomNumber);
  45. $updateProcedure->bindInteger($id);
  46. $updateProcedure->execute();
  47. $payload[] = $entry;
  48. }
  49. return new OKResponse(new JsonEntity($payload));
  50. }
  51. }