|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
[2019-06-03 11:27 UTC] daverandom@php.net
[2019-06-04 16:23 UTC] celsowm at gmail dot com
|
|||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Fri Oct 24 10:00:01 2025 UTC |
Description: ------------ I was trying to get all method for each PDO driver (I have all of them installed on my PC Windows). But if I try, for example, using Postgres (pdo_pgsql): var_dump(get_class_methods($pdo)); The result is: array(17) { [0]=> string(11) "__construct" [1]=> string(7) "prepare" [2]=> string(16) "beginTransaction" [3]=> string(6) "commit" [4]=> string(8) "rollBack" [5]=> string(13) "inTransaction" [6]=> string(12) "setAttribute" [7]=> string(4) "exec" [8]=> string(5) "query" [9]=> string(12) "lastInsertId" [10]=> string(9) "errorCode" [11]=> string(9) "errorInfo" [12]=> string(12) "getAttribute" [13]=> string(5) "quote" [14]=> string(8) "__wakeup" [15]=> string(7) "__sleep" [16]=> string(19) "getAvailableDrivers" } But this list is incomplete because PDO Postgres includes methods like: $pdo->pgsqlCopyToArray('my_table'); Test script: --------------- <?php $options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_EMULATE_PREPARES => false, ]; $server = "localhost"; $dsn = "pgsql:host=$server;port=5432;dbname=livraria;"; $user = "postgres"; $senha = "admin"; $pdo = new PDO($dsn, $user, $senha, $options); var_dump(get_class_methods($pdo)); var_dump(array_column((new ReflectionClass($pdo))->getMethods(), 'name')); var_dump($pdo->pgsqlCopyToArray('livro'));