I am trying to understand how/why fetch_assoc works the way it does. I have the following piece of code:
$results = $connectToDb->fetch(\"SELECT * FROM cust
I think it useful:
function get_posts(){
$posts = array();
if ($result = $mysqli->query("SELECT id, post_userid, name, lang, country, post_image, post_date, post_date_updated FROM posts ORDER BY `post_date` DESC ;")) {
while ($row = $result->fetch_assoc())
{
$posts[$row['id']] = $row ;
}
} else {
printf("Prepared Statement Error: %s\n", $mysqli->error);
}
return $posts;
}
Lets try to understand your code and how it works:
$results = $connectToDb->fetch("SELECT * FROM customer");
A variable $results has a collection of rows which are returned by a query. The size of the collection can be from 0 to n.
$resultsArray = $results->fetch_assoc();
This line fetch the first element from the collection. If the collection is empty it will return NULL.
while($row = $results->fetch_assoc()){
}
It can be decoupled in the following steps:
$row = $results->fetch_assoc() and return array with elements or NULL.$row = $results->fetch_assoc() in while with gotten value and get the following statements: while(array(with elements)) or while(NULL).while(array(with elements)) it resolves the while condition in True and allow to perform an iteration.while(NULL) it resolves the while condition in False and exits the loop.