
mysqli_stmt::bind_result 함수를 사용하여 결과를 바인딩 할 때, 쿼리에서 선택한 열의 순서에 따라 바인딩을 해야 합니다.
예를 들어, 다음과 같은 쿼리를 사용하여 결과를 얻을 때, 바인딩 순서를 어떻게 결정해야 하는지 알려드리겠습니다.
#hostingforum.kr
php
$stmt = $mysqli->prepare("SELECT name, age, email FROM users WHERE id = ?");
$stmt->bind_param("i", $id);
$stmt->execute();
$stmt->bind_result($name, $age, $email);
바인딩 순서는 쿼리에서 선택한 열의 순서와 동일해야 합니다. 따라서 위 예제에서는 $name, $age, $email 순서로 바인딩이 됩니다.
바인딩 순서가 id, name, age 순서로 바인딩이 되는 것은 아닙니다. id는 쿼리에서 WHERE 조건에 사용되기 때문에 바인딩이 되지 않습니다.
바인딩 순서를 결정하는 방법은 다음과 같습니다.
1. 쿼리에서 선택한 열의 순서를 확인합니다.
2. 바인딩 함수인 bind_result()에서 선택한 열의 순서를 지정합니다.
예를 들어, 다음과 같은 쿼리를 사용하여 결과를 얻을 때, 바인딩 순서를 어떻게 결정해야 하는지 알려드리겠습니다.
#hostingforum.kr
php
$stmt = $mysqli->prepare("SELECT name, age, email FROM users WHERE id = ?");
$stmt->bind_param("i", $id);
$stmt->execute();
$stmt->bind_result($age, $name, $email);
바인딩 순서는 쿼리에서 선택한 열의 순서와 동일해야 합니다. 따라서 위 예제에서는 $age, $name, $email 순서로 바인딩이 됩니다.
바인딩 순서를 결정하는 방법은 위와 같습니다.
2025-04-03 19:15