PHP Conference Japan 2024

dba_fetch

(PHP 4, PHP 5, PHP 7, PHP 8)

dba_fetch获取由键指定的數據

描述

dba_fetch(字符串|数组 $key, Dba\Connection $dba, 整数 $skip = 0): 字符串|false

从 8.3.0 开始,重载签名已弃用。

dba_fetch(字符串|数组 $key, 整数 $skip, 资源 $dba): 字符串

dba_fetch() 从由 dba 指定的数据库中获取由 key 指定的数据。

参数

key

数据由其指定的键。

注意:

在使用 inifiles 时,此函数接受数组作为键,其中索引 0 是组,索引 1 是值名称。参见:dba_key_split()

dba

一个 Dba\Connection 实例,由 dba_open()dba_popen() 返回。

skip

在使用 cdb 数据库时要忽略的键值对的数量。此值对于所有其他不支持具有相同名称的多个键的数据库都将被忽略。

返回值

如果找到键/数据对,则返回关联的字符串,否则返回 false

变更日志

版本 描述
8.4.0 dba 参数现在期望一个 Dba\Connection 实例;以前,期望一个有效的 dba 资源
8.3.0 现在已弃用使用 dba 作为第三个参数调用 dba_fetch()
8.2.0 dba_fetch() 的可选跳过参数现在位于末尾,与 PHP 用户空间语义一致。以前重载的签名仍然被接受,但不建议使用。

参见

添加注释

用户贡献的注释 1 个注释

2
khan666 at lycos dot co dot kr
14 年前
:: 提取数组排序。

例如)TEST_DATA.DB

1/korea/5000/word 1
10/japan/25000/word 10
21/china/130000/word 21
2/usa/35000/word 2

<?php
# 列表排序
$DB4_DATABASE = "TEST_DATA.DB4";
$DIV = "/";
$_FILE = "$DATA_DIR/HUTM_NETWORK_ROUTER.DB"; // DB4 文件名

$db = dba_open($DB4_DATABASE,"r","db4");
$key = dba_firstkey($db);
$ii = 0;
while(
$key != NULL)
{
$LIST[$ii] = explode($DIV,dba_fetch($key, $db)); // 提取数组
$key = dba_nextkey($db);
$ii++;
}
dba_close($db);
$total = $ii; // 总计

# 日期排序
sort($LIST,SORT_NUMERIC); // 数字键排序 ..

# 列表显示
for($i=0;$i<$total;$i++)
{
$oData = explode($DIV,$LIST[$i]); // 键 + 值(排序)

$key = trim(chop($oData[0])); # 键号
$name = trim(chop($oData[1])); # 名称
$count = trim(chop($oData[2])); # 数
$word = trim(chop($oData[3])); // 说明

echo "$key / $name / $count / $word <br>\r\n";
}
?>

::结果:

1/korea/5000/word 1
2/usa/35000/word 2
10/japan/25000/word 10
21/china/130000/word 21
To Top