forrest79 / phpgsql-nette
PhPgSql implementation into Nette Framework.
Requires
- php: ^8.1
- forrest79/phpgsql: ^1.7
- nette/di: ^3.0
Requires (Dev)
- doctrine/sql-formatter: ^1.5
- forrest79/phpcs: ^1.5
- forrest79/phpcs-ignores: ^0.5
- nette/tester: ^2.5
- phpstan/phpstan: ^2.1
- phpstan/phpstan-strict-rules: ^2.0
- tracy/tracy: ^2.10
Suggests
- doctrine/sql-formatter: For better formating SQL queries to Tracy bar and bluescreen.
- dev-master
- v1.6.3
- v1.6.2
- v1.6.1
- v1.6.0
- v1.5.3
- v1.5.2
- v1.5.1
- v1.5.0
- v1.4.4
- v1.4.3
- v1.4.2
- v1.4.1
- v1.4.0
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.0
- v1.1.1
- v1.1.0
- v1.0.0
- v0.10.0
- v0.9.3
- v0.9.2
- v0.9.1
- v0.9.0
- v0.8.9
- v0.8.8
- v0.8.7
- v0.8.6
- v0.8.5
- v0.8.4
- v0.8.3
- v0.8.2
- v0.8.1
- v0.8.0
- v0.7.1
- v0.7.0
- v0.6.4
- v0.6.3
- v0.6.2
- v0.6.1
- v0.6.0
- v0.5.0
- v0.4.2
- v0.4.1
- v0.4.0
- v0.3.1
- v0.3.0
- v0.2.0
- v0.1.0
This package is auto-updated.
Last update: 2025-01-08 21:42:00 UTC
README
Use PhPgSql with Nette Framework.
Introduction
Extension to easy use PhPgSql in Nette application.
Installation
The recommended way to install PhPgSql - Nette is through Composer:
composer require forrest79/phpgsql-nette
PhPgSql requires PHP 8.1.0 and pgsql binary extension.
Using
First, register extension in neon configuration:
extensions: database: Forrest79\PhPgSql\Nette\DI\Extension(%debugMode%)
Then, register connection (one connection is as default):
database: config: # default is empty array, keys and values are not checked, just imploded to `pg_connect` `$connection_string` as `"key1=value1 key2=value2 ..."` host: localhost port: 5432 user: postgres password: postgres dbname: postgres connect_timeout: 5 # good habit is to use connect_timeout parameter errorVerbosity: ::constant(PGSQL_ERRORS_VERBOSE) # default is NULL and it will use default error verbose PGSQL_ERRORS_DEFAULT, other value can be PGSQL_ERRORS_TERSE asyncWaitSeconds: 5 # default is NULL and it will use default seconds value rowFactory: @App\PhPgSql\Db\RowFactories\MyOwnRowFactory # this service is needed to be registered, default is NULL, and default row factory is used dataTypeParser: @App\PhPgSql\Db\DataTypeParsers\MyOwnDataTypeParser # this service is needed to be registered, default is NULL, and default data type parser is used dataTypeCache: @Forrest79\PhPgSql\Db\DataTypeCaches\PhpFile # this service is needed to be registered like this `- Forrest79\PhPgSql\Db\DataTypeCaches\PhpFile('%tempDir%/phpgsql/data-types-cache.php')`, this is recommended settings, default is NULL and cache is disabled forceNew: true # default is false async: true # default is false, when true, connection is made in async way, and it's not blocking the next PHP code execution (before the first query is run, a library is waiting for active connection) lazy: false # default is true, when false, connection is made right after the Connection object is created, when true, connection is made with the first query autowired: false # default is true (for second and next connection is always false) debugger: false # default is true (when true, the exception panel on Bluescreen is added, and Tracy bar is shown in debug mode) tracyBluescreenPanelClass: App\PhPgSql\MyOwnTracy\BarPanel # default is Forrest79\PhPgSql\Tracy\BluescreenPanel (you can use your own Tracy bluescreen panel class) tracyBarPanelClass: App\PhPgSql\MyOwnTracy\BarPanel # default is Forrest79\PhPgSql\Tracy\BarPanel (you can use your own Tracy bar panel class) queryDumper: false # default is null (when false, no query dumper is used, and all SQL queries are displayed as it is, when null - auto-detection is used - when Doctrine\Sql-Formatter is installed, it is used, when not, internal basic formatter is used or use own service via @serviceName) explain: true # default is false (when true, if the Tracy panel is enabled, explain is shown for every query) notices: true # default is false (when true, if the Tracy panel is enabled, after every SQL command and before connection is closed, notices are got and put into the query log) longQueryTimeMs: 100 # default is NULL = disabled, is set (float, time in milliseconds) and Tracy panel is enabled, all queries that takes longer than this value is marked in the panel with bold red time) repeatingQueries: true # default is FALSE (when true, if the Tracy panel is enabled, repeating queries are detected and listed - except BEGIN, COMMIT, ROLLBACK and SET statements) nonParsedColumns: true # default is FALSE (when true, if the Tracy panel is enabled, queries with some non-parsed (used) columns are detected and listed)
Or multiple connections:
database: first: config: host: localhost port: 5432 user: postgres password: postgres dbname: postgres second: config: host: localhost port: 5433 user: postgres password: postgres dbname: postgres
IMPORTANT! You can't name connection as
config
.
First connection
is autowired as Forrest79\PhPgSql\Fluent\Connection
. If you want to autowired other connection or none connection, you must explicitly set autowired: false
.
You can also get a connection by:
$container->getService('database.default.connection'); // for one connection, default $container->getService('database.first.connection');
Second can be got by:
$container->getService('database.second.connection');
Use your own connection class
By default Forrest79\PhPgSql\Fluent\Connection
is registered to DI as connection class. If you want to use other (your own) connection class, you need to use your own connection factory. This is class that implements Forrest79\PhPgSql\Nette\Connection\ConnectionCreator
interface, and you must specify the concrete return type with your connection class.
Example:
class ConnectionFactory implements Forrest79\PhPgSql\Nette\Connection\ConnectionCreator { /** @var int */ private $statementTimeout = NULL; public function __construct(int $sessionTimeout) { $this->statementTimeout = $sessionTimeout; } /** * In `$config` array are all values from connection config definition, you can use some special/meta values for your own logic and unset it from `$config` before sending it to `prepareConfig()` function. */ public function create(array $config, bool $forceNew, bool $async): MyOwnConnection { return (new Connection( $this->prepareConfig($config), // this will implode array config to string, you can extend this method and add some default settings or your own logic $forceNew, $async, ))->addOnConnect(function(Forrest79\PhPgSql\Db\Connection $connection) { $connection->query(sprintf('SET statement_timeout = %d', $this->statementTimeout)); }); } protected function prepareConfig(array $config): string { return parent::prepareConfig($config + ['connect_timeout' => 5]); } }
Function prepareConfig(array $config)
create connection string (key='value' key='value' ...
) from the array with configuration. Items with NULL
values are skipped.
And now, you just need to override old connection factory with this one in DI configuration, services
section, like this:
services: database.default.connection.factory: ConnectionFactory(15)
Where default
is connection name.
Query dumper
SQL queries are dumped in Tracy\Bar
and in Tracy\Bluescreen
and you can use different dumpers/formatters. Three are included:
PhPgSql\Tracy\QueryDumpers\NullDumper
- show SQL query as it is, it is used whenqueryDumper: false
is setPhPgSql\Tracy\QueryDumpers\Basic
- highlight and format SQL query with basic internal formatter, it is used whenqueryDumper: null
andDoctrine\Sql-Formatter
is not installedPhPgSql\Tracy\QueryDumpers\SqlFormatter
- highlight and format SQL query with Doctrine\Sql-Formatter, it is used whenqueryDumper: null
andDoctrine\Sql-Formatter
is installed
You can install better formatting via
Doctrine\Sql-Formatter
just for your dev environment withcomposer require doctrine/sql-formatter --dev
.
Or you can use your own query dumper, just create a class-extending abstract class PhPgSql\Tracy\QueryDumper
, register it to the DI container and set service to queryDumper: @class/serviceName
Tracy BarPanel
BarPanel
for Tracy
with DB queries is showing links to PHP source files, where the query was sent to the database. This is made using PHP function debug_backtrace()
.
This function returns the whole call stack. To get the correct place in the PHP source file, we must ignore some internal library classes where the query is sent to the database in real.
Basically, BarPanel
ignores all classes/function from PhPgSql library to show the most accurate place in the PHP source.
When you use some own custom wrapping objects, you want to ignore in the call stack, you can extend backtraceContinueIterate()
method and add your own logic here. For example:
protected static function backtraceContinueIterate(string $class, string $function): bool { return parent::backtraceContinueIterate() // just for sure, you can use multiple extends... || (is_a($class, MyOwnFluentQuery::class, TRUE) && ($function === 'count')) || (is_a($class, Mapper\Record::class, TRUE) && ($function === 'fetch')); }