PHPerKaigi 2025

dba_fetch

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

dba_fetchИзвлекает данные по указанному ключу

Описание

dba_fetch(string|array $key, Dba\Connection $dba, int $skip = 0): string|false

Перегруженная сигнатура устарела с PHP 8.3.0:

dba_fetch(string|array $key, int $skip, resource $dba): string

dba_fetch() извлекает данные из базы данных, заданной dba, определённые ключом key.

Список параметров

key

Ключ, для которого надо извлечь данные.

Замечание:

Когда работает с ini-файлом, эта функция принимает массив в качестве ключа, где по индексу 0 задана группа, а по индексу 1 - имя параметра. Дополнительно смотрите dba_key_split().

dba

Экземпляр класса Dba\Connection, который возвращают функции dba_open() и dba_popen().

skip

Число пар ключ-значение, которые нужно проигнорировать при работе с базой данных cdb. Этот параметр игнорируется при работе со всеми остальными базами данных, в которых не поддерживаются множественные ключи с одинаковым именем.

Возвращаемые значения

Возвращает строку, если пара ключ/данные найдена, иначе возвращает false.

Список изменений

Версия Описание
8.4.0 Параметр dba теперь ожидает экземпляр класса Dba\Connection; раньше параметр ждал ресурс (resource) dba .
8.3.0 Вызов функции dba_fetch() с параметром dba в качестве третьего аргумента устарел.
8.2.0 Необязательный параметр skip функции dba_fetch() теперь находится в конце в соответствии с пользовательской семантикой PHP; перегруженная сигнатура по-прежнему принимается, но не рекомендуется.

Смотрите также

  • dba_exists() - Проверяет, существует ли ключ
  • dba_delete() - Удаляет запись базы данных определённую ключом
  • dba_insert() - Вставляет запись
  • dba_replace() - Перезаписать или вставить запись
  • dba_key_split() - Разделяет ключ, заданный в виде строки, и создаёт массив из полученных частей

Добавить

Примечания пользователей 1 note

up
2
khan666 at lycos dot co dot kr
14 years ago
:: fetch array sort.

ex) TEST_DATA.DB

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

<?php
# LIST SORT
$DB4_DATABASE = "TEST_DATA.DB4";
$DIV = "/";
$_FILE = "$DATA_DIR/HUTM_NETWORK_ROUTER.DB"; // DB4 FileName

$db = dba_open($DB4_DATABASE,"r","db4");
$key = dba_firstkey($db);
$ii = 0;
while(
$key != NULL)
{
$LIST[$ii] = explode($DIV,dba_fetch($key, $db)); // fetch array
$key = dba_nextkey($db);
$ii++;
}
dba_close($db);
$total = $ii; // total count

# date sort
sort($LIST,SORT_NUMERIC); // numeric key sort ..

# list display
for($i=0;$i<$total;$i++)
{
$oData = explode($DIV,$LIST[$i]); // key + value (sort)

$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";
}
?>

::result::

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