PHPerKaigi 2025

dba_fetch

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

dba_fetchBusca dados especificados por chave

Descrição

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

Assinatura sobrecarregada, preterida a partir do PHP 8.3.0:

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

dba_fetch() busca os dados especificados pela chave em key do banco de dados especificado por dba.

Parâmetros

key

A chave pela qual os dados são especificados.

Nota:

Ao trabalhar com arquivos INI, eta função aceita arrays como chaves onde o índice 0 é o grupo e o índice 1 é o nome do valor. Consulte: dba_key_split().

dba

Uma instância de Dba\Connection, retornada por dba_open() ou dba_popen().

skip

O número de pares chave-valor a ignorar no uso de bancos de dados CDB. Este valor é ignorado para todos os outros bancos de dados que não suportam múltiplas chaves com o mesmo nome.

Valor Retornado

Retorna a string associada se o par chave/dados for encontrado, false caso contrário.

Registro de Alterações

Versão Descrição
8.4.0 O parâmetro dba agora espera uma instância deDba\Connection; anteriormente, um resource dba válido era esperado.
8.3.0 Chamar dba_fetch() com dba no 3º argumento agora está defasado.
8.2.0 O argumento opcional "skip" de dba_fetch() fica agora no final, alinhado com a semântica das funções de usuário do PHP. A assinatura anterior com sobrecarga ainda é aceita porém desencorajada.

Veja Também

adicione uma nota

Notas Enviadas por Usuários (em inglês) 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