(PHP 4, PHP 5)
mysql_data_seek — Move o ponteiro interno do resultado
$result
, int $row_number
)mysql_data_seek() move o ponteiro interno das linhas de um resultado MySQL associado ao identificador de resultado dado para o número da linha especificado. A próxima chamada a uma função MySQL que retorne resultado, como mysql_fetch_assoc(), irá retornar esta linha.
row_number
começa em 0. O
row_number
deve ser um valor no intervalo de 0 a
mysql_num_rows() - 1. Entretanto, se o conjunto de reseultados
for vazio ( mysql_num_rows() == 0), uma busca para 0
irá falhar com um E_WARNING e
mysql_data_seek() iá retornar FALSE
.
result
The result resource that is being evaluated. This result comes from a call to mysql_query().
row_number
O número de linha desejado para o ponteiro de resultado.
Retorna TRUE
em caso de sucesso ou FALSE
em caso de falha.
Exemplo #1 Exemplo mysql_data_seek()
<?php
$link = mysql_connect('localhost', 'mysql_user', 'mysql_password');
if (!$link) {
die('Não foi possível conectar: ' . mysql_error());
}
$db_selected = mysql_select_db('sample_db');
if (!$db_selected) {
die('Não foi possível selecionar o banco de dados: ' . mysql_error());
}
$query = 'SELECT last_name, first_name FROM friends';
$result = mysql_query($query);
if (!$result) {
die('A consulta falhou: ' . mysql_error());
}
/* obtém as linhas em ordem reversa */
for ($i = mysql_num_rows($result) - 1; $i >= 0; $i--) {
if (!mysql_data_seek($result, $i)) {
echo "Não foi possível mover para a linha $i: " . mysql_error() . "\n";
continue;
}
if (!($row = mysql_fetch_assoc($result))) {
continue;
}
echo $row['last_name'] . ' ' . $row['first_name'] . "<br />\n";
}
mysql_free_result($result);
?>
Nota:
A função mysql_data_seek() pode ser usada apenas em conjunto com a função mysql_query(), não com mysql_unbuffered_query().