I can create simple json objects like this:
$d = array(\'item\' => \"$name\" ,\'rate\' => \"$rating\");
But what if I want to build an ar
Why not create your array as you just have done but then pass the array through json_encode?
If you want a multi-dimensional array, try
$array[] = array("key1" => value1, "key2" => value2);
But I want multiple json objects in a json array when i encode it.
Then create an array of arrays and pass it to json_encode. The documentation about arrays explains how to add elements to an array, in the section Creating/modifying with square bracket syntax.
Associative arrays, like the one you already have, will be encoded as objects, "normal" arrays (arrays with consecutive numerical keys) will be encoded as arrays.
Example:
$d = array();
// This appends a new element to $d, in this case the value is another array
$d[] = array('item' => "$name" ,'rate' => "$rating");
$json = json_encode($d);
What you can do is create a php array dynamically as you want then covert it into a json array as below.
$json_array = json_encode($array);
Keep in mind that what you have provided is not a json array
This will create a multi-dimensional array from your database query, and then encode it as JSON.
$d = array();
while ($row = $stmt->fetch_assoc()) {
  $d[] = $row;
}
$json = json_encode($d);
Each $row will be an associative array of the data returned from the database. Assigning it to $d[] adds it as an indexed element of that container array.