TesteModel.php 999 B

12345678910111213141516171819202122232425262728293031323334
  1. <?php
  2. namespace Models;
  3. class TesteModel
  4. {
  5. private \PDO $pdo;
  6. public function __construct()
  7. {
  8. $dbFile = $_ENV['DB_FILE'];
  9. $dbPath = __DIR__ . '/../' . $dbFile;
  10. $this->pdo = new \PDO("sqlite:" . $dbPath);
  11. $this->pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
  12. }
  13. public function insert(string $field1, ?string $field2 = null): array
  14. {
  15. $stmt = $this->pdo->prepare("INSERT INTO teste (field1, field2) VALUES (:field1, :field2)");
  16. $stmt->execute([
  17. 'field1' => $field1,
  18. 'field2' => $field2
  19. ]);
  20. $id = (int)$this->pdo->lastInsertId();
  21. $stmt = $this->pdo->prepare("SELECT teste_id, field1, field2, created_at FROM teste WHERE teste_id = :id");
  22. $stmt->execute(['id' => $id]);
  23. $row = $stmt->fetch(\PDO::FETCH_ASSOC);
  24. if (!$row) {
  25. throw new \RuntimeException('Failed to fetch inserted record');
  26. }
  27. return $row;
  28. }
  29. }