_execute(); } /** * @return int|bool * @throws Exception */ public function save(): int|bool { return $this->_execute(); } /** * @return array|null * @throws Exception */ public function all(): ?array { [$pdo, $statement] = $this->search(); $statement->execute($this->params); $data = $statement->fetchAll(PDO::FETCH_ASSOC); $this->db->release($pdo); return $data; } /** * @return array|null * @throws Exception */ public function one(): ?array { [$pdo, $statement] = $this->search(); $statement->execute($this->params); $data = $statement->fetch(PDO::FETCH_ASSOC); $this->db->release($pdo); return $data; } /** * @return mixed * @throws Exception */ public function fetchColumn(): mixed { [$pdo, $statement] = $this->search(); $statement->execute($this->params); $data = $statement->fetchColumn(PDO::FETCH_ASSOC); $this->db->release($pdo); return $data; } /** * @return ?int * @throws Exception */ public function rowCount(): ?int { [$pdo, $statement] = $this->search(); $statement->execute($this->params); $data = $statement->rowCount(); $this->db->release($pdo); return $data; } /** * @return int|bool * @throws Exception */ public function flush(): int|bool { return $this->_execute(); } /** * @return bool|int * @throws Exception */ private function _execute(): bool|int { $pdo = $this->db->getPdo(); try { if (!(($prepare = $pdo->prepare($this->sql)) instanceof PDOStatement)) { throw new Exception($prepare->errorInfo()[2] ?? static::DB_ERROR_MESSAGE); } if ($prepare->execute($this->params) === false) { throw new Exception($prepare->errorInfo()[2] ?? static::DB_ERROR_MESSAGE); } $result = (int)$pdo->lastInsertId(); $prepare->closeCursor(); $this->db->release($pdo); return $result == 0 ? true : $result; } catch (\PDOException|\Throwable $throwable) { if (str_contains($throwable->getMessage(), 'MySQL server has gone away')) { $this->db->restore(); return $this->_execute(); } $this->db->release($pdo); return $this->logger->addError($this->sql . '. error: ' . $throwable->getMessage(), 'mysql'); } } /** * @return array|bool * @throws Exception */ private function search(): bool|array { $pdo = $this->db->getSlaveClient(); try { if (($statement = $pdo->prepare($this->sql)) === false) { throw new Exception($pdo->errorInfo()[1]); } return [$pdo, $statement]; } catch (\Throwable $throwable) { if (str_contains($throwable->getMessage(), 'MySQL server has gone away')) { $this->db->restore(); return $this->search(); } $this->db->release($pdo); return $this->logger->addError($this->sql . '. error: ' . $throwable->getMessage(), 'mysql'); } } /** * @return int|bool * @throws Exception */ public function delete(): int|bool { return $this->_execute(); } /** * @return int|bool * @throws Exception */ public function exec(): int|bool { return $this->_execute(); } /** * @param array $data * @return $this */ public function bindValues(array $data = []): static { if (count($data) > 0) { $this->params = array_merge($this->params, $data); } return $this; } /** * @param $sql * @return $this * @throws Exception */ public function setSql($sql): static { $this->sql = $sql; return $this; } }