Zakładając, że nie możesz użyć get_result()
i potrzebujesz szeregu urządzeń, możesz zrobić:
public function getAllDevices($user_id) {
$stmt = $this->conn->prepare("SELECT device_id, device_name, device_info FROM devices WHERE primary_owner_id = ?");
$stmt->bind_param("i", $user_id);
$stmt->execute();
$stmt->bind_result($id, $name, $info);
$devices = array();
while($stmt->fetch()) {
$tmp = array();
$tmp["id"] = $id;
$tmp["name"] = $name;
$tmp["info"] = $info;
array_push($devices, $tmp);
}
$stmt->close();
return $devices;
}
Tworzy to tymczasową tablicę i przechowuje w niej dane z każdego wiersza, a następnie przesyła je do głównej tablicy. O ile mi wiadomo, nie możesz użyć SELECT *
w bind_result()
. Zamiast tego będziesz musiał irytująco wpisywać wszystkie żądane pola po SELECT