PHP Conference Japan 2024

mysqli_result::$lengths

mysqli_fetch_lengths

(PHP 5, PHP 7, PHP 8)

mysqli_result::$lengths -- mysqli_fetch_lengths返回结果集中当前行各列的长度

描述

面向对象风格

过程化风格

mysqli_fetch_lengths(mysqli_result $result): 数组|false

函数 mysqli_fetch_lengths() 返回一个数组,其中包含结果集中当前行中每一列的长度。

参数

result

仅过程化风格:由 mysqli_query()mysqli_store_result()mysqli_use_result()mysqli_stmt_get_result() 返回的 mysqli_result 对象。

返回值

一个整数数组,表示每一列的大小(不包括任何终止空字符)。如果发生错误,则返回 false

mysqli_fetch_lengths() 仅对结果集的当前行有效。如果在调用 mysqli_fetch_row/array/object 之前或在检索结果集中的所有行之后调用它,则返回 false

范例

示例 #1 面向对象风格

<?php
$mysqli
= new mysqli("localhost", "my_user", "my_password", "world");

/* 检查连接 */
if (mysqli_connect_errno()) {
printf("连接失败:%s\n", mysqli_connect_error());
exit();
}

$query = "SELECT * from Country ORDER BY Code LIMIT 1";

if (
$result = $mysqli->query($query)) {

$row = $result->fetch_row();

/* 显示列长度 */
foreach ($result->lengths as $i => $val) {
printf("字段 %2d 的长度为 %2d\n", $i+1, $val);
}
$result->close();
}

/* 关闭连接 */
$mysqli->close();
?>

示例 #2 过程化风格

<?php
$link
= mysqli_connect("localhost", "my_user", "my_password", "world");

/* 检查连接 */
if (mysqli_connect_errno()) {
printf("连接失败:%s\n", mysqli_connect_error());
exit();
}

$query = "SELECT * from Country ORDER BY Code LIMIT 1";

if (
$result = mysqli_query($link, $query)) {

$row = mysqli_fetch_row($result);

/* 显示列长度 */
foreach (mysqli_fetch_lengths($result) as $i => $val) {
printf("字段 %2d 的长度为 %2d\n", $i+1, $val);
}
mysqli_free_result($result);
}

/* 关闭连接 */
mysqli_close($link);
?>

以上示例将输出

Field  1 has Length  3
Field  2 has Length  5
Field  3 has Length 13
Field  4 has Length  9
Field  5 has Length  6
Field  6 has Length  1
Field  7 has Length  6
Field  8 has Length  4
Field  9 has Length  6
Field 10 has Length  6
Field 11 has Length  5
Field 12 has Length 44
Field 13 has Length  7
Field 14 has Length  3
Field 15 has Length  2
添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top