结果集中的字段与指针操作
<?php
/**
* 结果集中的字段与指针操作
*/
require 'mysqli_connect.php';
if ($res = mysqli_query($db, "select * from staff limit 5")) {
while($row = mysqli_fetch_assoc($res)){
print_r($row); echo '<br>';
}
echo '<hr>';
echo '表中的记录数量是:'.mysqli_num_rows($res).'<br>';
echo '表中记录的字段数量是:'.mysqli_num_fields($res).'<br>';
echo '当前字段数量'.mysqli_field_count($db).'<br>'; //注意参数必须是$db
echo '当前字段在结果集中的位置'.mysqli_field_tell($res).'<br>';
// var_dump(mysqli_fetch_field($res)); //以对象方式查看当前字段的详细信息
// mysqli_field_seek($res,2); //移动字段指针
//用循环来遍历字段结果集
for ($i=0; $i<mysqli_num_fields($res); $i++) {
mysqli_field_seek($res,$i);
var_dump(mysqli_fetch_field($res));
}
echo '<hr>';
//不需要循环遍历,快速获取全部字段的对象表示
var_dump(mysqli_fetch_fields($res));
/**
* 如果要获取某一个字段的对象表示,应该分二步
* 1. 移动字段指针对指定位置: mysqli_field_seek($res,2);指向第3个字段
* 2. 查询当前位置的字段对象信息: mysqli_fetch_field($res)
*/
echo '<hr>';
mysqli_field_seek($res,2);
var_dump(mysqli_fetch_field($res));
echo '<hr color="red">';
//其实,mysqli提供一个更简便的方法一步就可以实现上面二步完成的操作:
var_dump(mysqli_fetch_field_direct($res,2));
//例如我们要获取一下字段名称:
$field_info = mysqli_fetch_field_direct($res,2);
echo '第3个字段的名称是:'.$field_info->name;
}
mysqli_close($db);点击 "运行实例" 按钮查看在线实例
结果集中的记录指针与遍历操作
<?php
/**
* 结果集中的记录指针与遍历操作
*/
require 'mysqli_connect.php';
if ($res = mysqli_query($db, "select * from staff limit 5")) {
while($row = mysqli_fetch_assoc($res)){
print_r($row); echo '<br>';
}
echo '<hr>';
//将结果集中的记录指针定位到0,即第1条记录
mysqli_data_seek($res,0);
print_r(mysqli_fetch_assoc($res));
echo '<br>';
//将结果集中的记录指针定位到2,即第3条记录
mysqli_data_seek($res,2);
print_r(mysqli_fetch_assoc($res));
echo '<br>';
//那么最后一条记录的指针是多少呢?对,行数-1
mysqli_data_seek($res,mysqli_num_rows($res)-1);
print_r(mysqli_fetch_assoc($res));
echo '<br>';
//知道规律了,下面我们用for循环来遍历这个这个结果集
echo '<hr color="red">';
for($i=0; $i<mysqli_num_rows($res); $i++) {
mysqli_data_seek($res,$i);
print_r(mysqli_fetch_assoc($res));
echo '<br>';
}
//恭喜大家又学到了一种遍历结果集的方法
}
mysqli_close($db);点击 "运行实例" 按钮查看在线实例
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号