PHP Conference Japan 2024

mysqli::options

mysqli_options

(PHP 5, PHP 7, PHP 8)

mysqli::options -- mysqli_options设置选项

描述

面向对象风格

public mysqli::options(int $option, string|int $value): bool

过程式风格

mysqli_options(mysqli $mysql, int $option, string|int $value): bool

用于设置额外的连接选项并影响连接的行为。

此函数可以多次调用以设置多个选项。

mysqli_options() 应该在 mysqli_init()之后以及 mysqli_real_connect() 之前调用。

参数

mysql

仅过程式风格:由 mysqli_connect()mysqli_init() 返回的 mysqli 对象

option

要设置的选项。它可以是以下值之一

有效选项
名称 描述
MYSQLI_OPT_CONNECT_TIMEOUT 连接超时时间(秒)
MYSQLI_OPT_READ_TIMEOUT 命令执行结果超时时间(秒)。从PHP 7.2.0开始可用。
MYSQLI_OPT_LOCAL_INFILE 启用/禁用 LOAD LOCAL INFILE 的使用
MYSQLI_INIT_COMMAND 连接到MySQL服务器后要执行的命令
MYSQLI_SET_CHARSET_NAME 要设置为默认的字符集。
MYSQLI_READ_DEFAULT_FILE 从指定的选项文件读取选项,而不是从 my.cnf。mysqlnd不支持。
MYSQLI_READ_DEFAULT_GROUP my.cnf 中指定的组或使用 MYSQL_READ_DEFAULT_FILE 指定的文件中读取选项。mysqlnd不支持。
MYSQLI_SERVER_PUBLIC_KEY 与基于SHA-256的身份验证一起使用的RSA公钥文件。
MYSQLI_OPT_NET_CMD_BUFFER_SIZE 内部命令/网络缓冲区的大小。仅适用于mysqlnd。
MYSQLI_OPT_NET_READ_BUFFER_SIZE 读取MySQL命令包正文时的最大读取块大小(字节)。仅适用于mysqlnd。
MYSQLI_OPT_INT_AND_FLOAT_NATIVE 使用非预处理语句时,将整数和浮点数列转换回PHP数字。仅适用于mysqlnd。
MYSQLI_OPT_SSL_VERIFY_SERVER_CERT 是否验证服务器证书。

value

选项的值。

返回值

成功时返回 true,失败时返回 false

错误/异常

如果启用了mysqli错误报告 (MYSQLI_REPORT_ERROR),并且请求的操作失败,则会生成警告。如果此外模式设置为 MYSQLI_REPORT_STRICT,则会抛出 mysqli_sql_exception

示例

参见 mysqli_real_connect()

注释

注意:

MySQLnd始终假定服务器默认字符集。此字符集在连接握手/身份验证期间发送,mysqlnd将使用它。

libmysqlclient 使用在 my.cnf 中设置的默认字符集,或者在调用 mysqli_real_connect() 之前(但 mysqli_init() 之后)通过显式调用 mysqli_options() 设置。

参见

添加注释

用户贡献的注释 6 条注释

php at darkain dot com
6年前
有一个未记录的选项:MYSQLI_OPT_READ_TIMEOUT。理论上,这类似于MYSQLI_OPT_CONNECT_TIMEOUT,但应用略有不同。连接超时仅指定初始TCP连接的等待时间。一旦创建,超时就不再适用。但是,读取超时是从创建TCP连接到收到第一包实际数据的时间。在某些情况下,可以建立TCP连接,但MySQL服务器无限期地停滞,阻止执行返回PHP。指定读取超时可以缓解这种情况,而连接超时则不行。

如果未定义MYSQLI_OPT_READ_TIMEOUT常量,则仍然支持在没有此常量的版本中使用。您可以在旧版本的PHP中使用以下代码自行定义它。

<?php
if (!defined('MYSQLI_OPT_READ_TIMEOUT')) {
define ('MYSQLI_OPT_READ_TIMEOUT', 11);
}
?>

然后,您可以像使用连接超时一样使用读取超时。请注意,由于这两个值是针对整个连接过程的不同部分的两个不同的超时值,因此超时会累加(例如:10秒连接超时 + 10秒读取超时 = 最大可能的20秒超时)

<?php
// 创建对象
$connection = mysqli_init();

// 指定连接超时
$connection->options(MYSQLI_OPT_CONNECT_TIMEOUT, 10);

// 指定读取超时
$connection->options(MYSQLI_OPT_READ_TIMEOUT, 10);

// 使用先前指定的超时启动与服务器的连接
$connection->real_connect('server', 'user', 'pass', 'database');
?>
fluppy
17年前
这里是一个创建SSL连接的小例子

<?php

$db
= mysqli_init();

/*
当您想使用单独的cnf时
$test = $db->options(MYSQLI_EAD_DEFAULT_FILE,'myother.cnf');
*/

$db->ssl_set('server-key.pem','server-cert.pem',
'cacert.pem',NULL,NULL);

$db->real_connect('localhost','root','','mydb');

// 这里有一些查询

$db->close();

?>
Procedural Man
2年前
虽然手册中没有解释,但MYSQLI_OPT_SSL_VERIFY_SERVER_CERT选项仅对mysqlnd有效,如果与mysqli一起使用,则会引发错误。
puneetsharam9 at hotmail dot com
2年前
使用面向对象方法
mysqli的初始化从8.1开始似乎已弃用
您可能需要使用一个空的__construct()
这样您就可以正确获得整数和浮点数

class DB extends \mysqli {
私有函数 __construct(
私有 $_user = DBUSER,
私有 $_pass = DBPWD,
私有 $_dbName = DBNAME,
私有 $_dbHost = DBHOST,
) {
parent::__construct();
parent::options(MYSQLI_OPT_INT_AND_FLOAT_NATIVE, 1);
parent::real_connect($this->_dbHost, $this->_user, $this->_pass, $this->_dbName);
}
}
Guy Sartorelli
1年前
`MYSQLI_OPT_SSL_VERIFY_SERVER_CERT` 似乎总是失败,`options()` 总是返回 false。
改用 `real_connect()` 中的 `MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT` 标志。
king at bobfish dot org
16年前
使用 mysqli_options 来增加 max_allowed_packet 大小以处理大型 Blob 的示例。

函数 dbConnect()
{
$user = 'jomama';
$pass = 'cartoon';
$dbName = 'LifeCycle';
$host = 'localhost';

$mysqli = mysqli_init();
mysqli_options($mysqli, MYSQLI_READ_DEFAULT_GROUP,
"max_allowed_packet=50M");
mysqli_real_connect($mysqli,$host, $user, $pass,$dbName)
or die ('<P>无法连接</P>');

return $mysqli;
}
To Top