mysql_data_seek
(PHP 4, PHP 5)
mysql_data_seek — 내부 결과 포인터 이동
경고 이 확장은 PHP 5.5.0에서 더 이상 사용되지 않으며 PHP 7.0.0에서 제거되었습니다. 대신 MySQLi 또는 PDO_MySQL 확장을 사용해야 합니다. MySQL: API 선택 가이드도 참조하세요. 이 함수의 대안은 다음과 같습니다.
- mysqli_data_seek()
-
PDO::FETCH_ORI_ABS
설명
mysql_data_seek(resource $result
, int $row_number
): bool
mysql_data_seek()는 지정된 결과 식별자와 연관된 MySQL 결과의 내부 행 포인터를 지정된 행 번호를 가리키도록 이동합니다. mysql_fetch_assoc()와 같은 MySQL 페치 함수에 대한 다음 호출은 해당 행을 반환합니다.
row_number
는 0에서 시작합니다. row_number
는 0에서 mysql_num_rows() - 1 사이의 값이어야 합니다. 그러나 결과 세트가 비어 있는 경우(mysql_num_rows() == 0), 0에 대한 탐색은 E_WARNING
과 함께 실패하고 mysql_data_seek()는 false
를 반환합니다.
매개변수
result
- 평가 중인 결과 리소스입니다. 이 결과는 mysql_query()에 대한 호출에서 비롯됩니다.
row_number
- 새 결과 포인터의 원하는 행 번호입니다.
반환 값
성공하면 true
를, 실패하면 false
를 반환합니다.
Examples
예제 #1 mysql_data_seek() 예제
<?php
$link = mysql_connect('localhost', 'mysql_user', 'mysql_password');
if (!$link) {
die('Could not connect: ' . mysql_error());
}
$db_selected = mysql_select_db('sample_db');
if (!$db_selected) {
die('Could not select database: ' . mysql_error());
}
$query = 'SELECT last_name, first_name FROM friends';
$result = mysql_query($query);
if (!$result) {
die('Query failed: ' . mysql_error());
}
/* fetch rows in reverse order */
for ($i = mysql_num_rows($result) - 1; $i >= 0; $i--) {
if (!mysql_data_seek($result, $i)) {
echo "Cannot seek to row $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);
?>
노트
참고:
mysql_data_seek() 함수는 mysql_unbuffered_query()가 아닌 mysql_query()와 함께 사용할 수 있습니다.
기타
- mysql_query() - MySQL 쿼리 보내기
- mysql_num_rows() - 결과의 행 수 가져오기
- mysql_fetch_row() - 열거된 배열에서 결과 행 가져오기
- mysql_fetch_assoc() - 연관 배열에서 결과 행 가져오기
- mysql_fetch_array() - 결과 행을 연관 배열, 숫자 배열 또는 둘 다로 가져옵니다.
- mysql_fetch_object() - 결과 행을 객체로 가져오기