1
0
mirror of https://github.com/danog/postgres.git synced 2025-01-06 13:08:25 +01:00
postgres/lib/PqStatement.php

65 lines
1.5 KiB
PHP
Raw Normal View History

2016-12-30 06:21:17 +01:00
<?php
2016-09-14 16:27:39 +02:00
namespace Amp\Postgres;
use Amp\Promise;
2016-09-14 16:27:39 +02:00
use pq;
class PqStatement implements Statement {
/** @var \pq\Statement */
private $statement;
/** @var callable */
private $execute;
/** @var callable */
private $deallocate;
2017-11-18 06:55:16 +01:00
/** @var \Amp\Postgres\Internal\ReferenceQueue */
private $queue;
2016-09-14 16:27:39 +02:00
/**
* @internal
*
2016-09-14 16:27:39 +02:00
* @param \pq\Statement $statement
* @param callable $execute
* @param callable $deallocate
2016-09-14 16:27:39 +02:00
*/
public function __construct(pq\Statement $statement, callable $execute, callable $deallocate) {
2016-09-14 16:27:39 +02:00
$this->statement = $statement;
$this->execute = $execute;
$this->deallocate = $deallocate;
2017-11-18 06:55:16 +01:00
$this->queue = new Internal\ReferenceQueue;
2016-09-14 16:27:39 +02:00
}
2017-05-16 06:28:37 +02:00
2016-09-14 16:27:39 +02:00
public function __destruct() {
($this->deallocate)($this->statement->name);
2017-11-18 06:55:16 +01:00
$this->queue->unreference();
2016-09-14 16:27:39 +02:00
}
2017-05-16 06:28:37 +02:00
2016-09-14 16:27:39 +02:00
/**
* @return string
*/
public function getQuery(): string {
return $this->statement->query;
}
/**
* @param mixed ...$params
*
* @return \Amp\Promise<\Amp\Postgres\Result>
2016-09-14 16:27:39 +02:00
*
* @throws \Amp\Postgres\FailureException If executing the statement fails.
*/
public function execute(array $params = []): Promise {
return ($this->execute)([$this->statement, "execAsync"], $params);
2016-09-14 16:27:39 +02:00
}
2017-11-18 06:55:16 +01:00
/**
* @param callable $onDestruct
*/
public function onDestruct(callable $onDestruct) {
$this->queue->onDestruct($onDestruct);
}
2017-05-16 06:28:37 +02:00
}