123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- <?php
- namespace Benchmark\Resources;
- use Benchmark\Entities\RandomNumber;
- use Hamlet\Database\Database;
- use Hamlet\Http\Entities\JsonEntity;
- use Hamlet\Http\Requests\Request;
- use Hamlet\Http\Resources\HttpResource;
- use Hamlet\Http\Responses\Response;
- use Hamlet\Http\Responses\SimpleOKResponse;
- class UpdateResource implements HttpResource
- {
- private $database;
- public function __construct(Database $database)
- {
- $this->database = $database;
- }
- public function getResponse(Request $request): Response
- {
- $count = $request->parameter('queries');
- if ($count !== null && $count > 0) {
- $count = min($count, 500);
- } else {
- $count = 1;
- }
- $selectQuery = '
- SELECT id,
- randomNumber
- FROM World
- WHERE id = ?
- ';
- $selectProcedure = $this->database->prepare($selectQuery);
- $updateQuery = '
- UPDATE World
- SET randomNumber = ?
- WHERE id = ?
- ';
- $updateProcedure = $this->database->prepare($updateQuery);
- $payload = [];
- while ($count-- > 0) {
- $id = mt_rand(1, 10000);
- $randomNumber = mt_rand(1, 10000);
- $selectProcedure->bindInteger($id);
- /** @var RandomNumber $entry */
- $entry = $selectProcedure->processOne()->selectAll()->cast(RandomNumber::class)->collectHead();
- $modifiedEntry = $entry->withNumber($randomNumber);
- $updateProcedure->bindInteger($modifiedEntry->number());
- $updateProcedure->bindInteger($modifiedEntry->id());
- $updateProcedure->execute();
- $payload[] = $modifiedEntry;
- }
- return new SimpleOKResponse(new JsonEntity($payload));
- }
- }
|