To use "PDO::MYSQL_ATTR_USE_BUFFERED_QUERY" you should call
PDO::setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, true);
It will not work when passed into PDO::prepare()
PDO_MYSQL é um driver que implementa a interface PHP Data Objects (PDO) para habilitar o acesso do PHP aos bancos de dados MySQL.
PDO_MYSQL utiliza as preparações emuladas por padrão.
MySQL 8
Ao executar uma versão de PHP anterior a 7.1.16, ou 7.2.4, defina o plugin padrão de senhas do Servidor MySQL 8 para mysql_native_password ou poderão surgir erros similares a The server requested authentication method unknown to the client [caching_sha2_password] mesmo quando caching_sha2_password não seja usado.
Isto acontece porque o padrão do MySQL 8 é caching_sha2_password, um plugin que não
é reconhecido pelas versões antigas do PHP (mysqlnd). Portanto, altere o plugin
configurando default_authentication_plugin=mysql_native_password
no arquivo my.cnf. O plugin caching_sha2_password
é totalmente suportado a partir do PHP 7.4.4. Para versões anteriores do PHP, a extensão
mysql_xdevapi suporta
o plugin.
Cuidado: Alguns tipos de tabelas do MySQL (motores de armazenamento) não suportam transações. Ao escrever código para um banco de dados transacional onde o tipo de tabela não suporta transações, o MySQL irá entender que a transação foi inicializada com sucesso. Além disso, qualquer consulta DDL irá, de forma implícita, executar o "commit" para qualquer transação que esteja pendente.
Nota:
O driver MySQL não suporta adequadamente a opção
PDO::PARAM_INPUT_OUTPUT
através de PDOStatement::bindParam(); embora tais parâmetros possam ser usados, eles não são atualizados (isto é, a saída real é ignorada).
As distribuições Unix comuns incluem versões binárias do PHP que podem ser instaladas. Embora estas versões binárias são tipicamente compiladas com suporte a extensões MySQL, as bibliotecas das extensões em si podem precisar ser instaladas usando um pacote adicional. Verifique o gerenciador de pacote que vem com a distribuição sendo usada para disponibilidade desse pacote.
Por exemplo, no Ubuntu o pacote php5-mysql
instala
as extensões PHP ext/mysql, ext/mysqli e PDO_MYSQL. No CentOS,
o pacote php-mysql
também instala estas três
extensões.
Alternativamente, o usuário pode compilar esta extensão por conta própria. Compilar o PHP direto da fonte permite especificar as extensões a serem utilizadas, assim como as bibliotecas clientes para cada extensão.
Ao compilar, use a opção --with-pdo-mysql[=DIR] para instalar
a extensão PDO MySQL, onde o [=DIR]
opcional
é a localização da biblioteca base do MySQL. Mysqlnd
é a biblioteca principal. Para detalher sobre a escolha de biblioteca, consulte a seção
Escolhendo uma biblioteca MySQL.
Opcionalmente, --with-mysql-sock[=DIR] define a localização do ponteiro do soquete Unix MySQL para todas as extensões MySQL, incluindo a PDO_MYSQL. Se não especificada, as localizações padrão são pesquisadas.
Optionalmente, --with-zlib-dir[=DIR] é usada para definir o caminho da instalação da zlib.
$ ./configure --with-pdo-mysql --with-mysql-sock=/var/mysql/mysql.sock
O suporte a SSL é habilitado usando as constantes
Pdo\Mysql::ATTR_SSL_*
apropriadas,
que é o equivalente a chamar a
» função mysql_ssl_set() da API C do MySQL.
Além disso, o SSL não pode ser habilitado com PDO::setAttribute()
porque a conexão já existirá.
Consulte também a documentação do MySQL sobre
» conexão ao MySQL com SSL.
As constantes abaixo são definidas por
este driver e só estarão disponíveis quando a extensão tiver sido
compilada no PHP ou tiver sido carregada dinamicamente em tempo de execução. Além disso, estas
constantes específicas do driver só devem ser usadas se este driver estiver sendo usado.
Usar atributos específicos de um driver com outro driver pode resultar em
comportamento inesperado. PDO::getAttribute() pode ser usada para
obter o atributo PDO::ATTR_DRIVER_NAME
para verificar o
driver, se o código puder ser executado com vários drivers.
PDO::MYSQL_ATTR_USE_BUFFERED_QUERY
(int)
Pdo\Mysql::ATTR_USE_BUFFERED_QUERY
.
PDO::MYSQL_ATTR_LOCAL_INFILE
(int)
Pdo\Mysql::ATTR_LOCAL_INFILE
PDO::MYSQL_ATTR_LOCAL_INFILE_DIRECTORY
(int)
Pdo\Mysql::ATTR_LOCAL_INFILE_DIRECTORY
.
Disponível a partir do PHP 8.1.0.
PDO::MYSQL_ATTR_INIT_COMMAND
(int)
Pdo\Mysql::ATTR_INIT_COMMAND
.
PDO::MYSQL_ATTR_READ_DEFAULT_FILE
(int)
Pdo\Mysql::ATTR_READ_DEFAULT_FILE
.
PDO::MYSQL_ATTR_READ_DEFAULT_GROUP
(int)
Pdo\Mysql::ATTR_READ_DEFAULT_GROUP
.
PDO::MYSQL_ATTR_MAX_BUFFER_SIZE
(int)
Pdo\Mysql::ATTR_MAX_BUFFER_SIZE
.
PDO::MYSQL_ATTR_DIRECT_QUERY
(int)
PDO::ATTR_EMULATE_PREPARES
.
PDO::MYSQL_ATTR_FOUND_ROWS
(int)
Pdo\Mysql::ATTR_FOUND_ROWS
.
PDO::MYSQL_ATTR_IGNORE_SPACE
(int)
Pdo\Mysql::ATTR_IGNORE_SPACE
.
PDO::MYSQL_ATTR_COMPRESS
(int)
Pdo\Mysql::ATTR_COMPRESS
.
PDO::MYSQL_ATTR_SERVER_PUBLIC_KEY
(int)
Pdo\Mysql::ATTR_SERVER_PUBLIC_KEY
.
PDO::MYSQL_ATTR_SSL_CA
(int)
Pdo\Mysql::ATTR_SSL_CA
.
PDO::MYSQL_ATTR_SSL_CAPATH
(int)
Pdo\Mysql::ATTR_SSL_CAPATH
.
PDO::MYSQL_ATTR_SSL_CERT
(int)
Pdo\Mysql::ATTR_SSL_CERT
.
PDO::MYSQL_ATTR_SSL_CIPHER
(int)
Pdo\Mysql::ATTR_SSL_CIPHER
.
PDO::MYSQL_ATTR_SSL_KEY
(int)
Pdo\Mysql::ATTR_SSL_KEY
.
PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT
(int)
Pdo\Mysql::ATTR_SSL_VERIFY_SERVER_CERT
.
Disponível a partir do PHP 7.0.18 e PHP 7.1.4.
PDO::MYSQL_ATTR_MULTI_STATEMENTS
(int)
Pdo\Mysql::ATTR_MULTI_STATEMENTS
.
O comportamento destas funções é afetado pelas configurações do php.ini.
Nome | Padrão | Modificável |
---|---|---|
pdo_mysql.default_socket | "/tmp/mysql.sock" | INI_SYSTEM |
pdo_mysql.debug | NULL | INI_SYSTEM |
Aqui está uma breve explicação das diretivas de configuração.
pdo_mysql.default_socket
string
Define um soquete de domínio Unix. Este valor também pode ser definido no momento da compilação se um soquete de domínio puder ser encontrado durante o comando "configure". Esta configuração ini é apenas para sistemas baseados em Unix.
pdo_mysql.debug
bool
Habilita a depuração para o PDO_MYSQL. Esta configuração está disponível somente quando o PDO_MYSQL tiver sido compilado com a mysqlnd e em modo de depuração PDO.
To use "PDO::MYSQL_ATTR_USE_BUFFERED_QUERY" you should call
PDO::setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, true);
It will not work when passed into PDO::prepare()
SQLSTATE[HY000]: General error: 2014 Cannot execute queries while other unbuffered queries are active. ...
After spending hours trying to track down why we were getting this error on a new server, after the same code ran fine on other servers, we found the problem to be an old MySQL _client_ library running on our web server, and a latest-version MySQL _server_ running on the database server's box.
Upgraded the MySQL client on the web server to the current revision and the problem went away.
> change it by setting default_authentication_plugin=mysql_native_password in my.cnf
This only works in MySQL 8.0. The default_authentication_plugin variable has been removed from 8.4.