Ich habe eine MySQL-Datenbank, ich benutze Ajax, um es über PHP abzufragen, es funktioniert gut, wenn nur eine einzige Zeile zurückgegeben wird es Fehler heraus, wenn mehrere Zeilen zurückgegeben werden.Umgang mit mehreren db Zeilen mit Ajax und JSON
Hier ist der Code, den ich benutze, jede Hilfe wäre sehr geschätzt.
$('button').click(function(){
event.preventDefault();
var box = document.getElementById('machine');
var rdata;
var id= box.options[box.selectedIndex].text;
$.ajax({
url: 'machine_report.php',
data: 'machine=' + id,
dataType: 'json',
success: function(rdata)
{
var uid = rdata[0];
var date = rdata[1];
var time = rdata[2];
var machine =rdata[3];
var reps = rdata[4];
var sets = rdata[5];
var weight = rdata[6];
var settings = rdata[7];
$('#status').html("<b>id: </b>"+uid+"<b> date: </b>"+date + "<b> Machine: </b>" + machine + "<b> reps: </b>" + reps + "<b> sets: </b>" +
sets + "<b> weight: </b>" + weight + "<b> settings: </b>" + settings);
},
error: function(xhr,textStatus, errorThrown) {
$("#status").html("xhr=" + xhr + "textStatus=" + textStatus + "errorThrown= " + errorThrown);
}
});
});
PHP-Code
<?php
require_once("connect.php");
$machine = $_GET['machine'];
$mysql="SELECT * FROM workouts WHERE machine LIKE '$machine' ORDER BY uid DESC";
$result=mysqli_query($con,$mysql);
if (!$result) {
printf("Error: %s\n", mysqli_error($con));
exit();
}
$rowCount = mysqli_affected_rows($con);
while($row = mysqli_fetch_array($result)){
$date = $row['date'];
$time = $row['time'];
$machine = $row['machine'];
$reps = $row['reps'];
$sets = $row['sets'];
$weight = $row['weight'];
$settings = $row['settings'];
echo json_encode($row);
}
?>
Der JS-Code ist nicht nützlich. Ihr Server erzeugt einen schlechten JSON, daher müssen Sie den serverseitigen Code anzeigen. –
while ($ row = mysqli_fetch_assoc ($ ergebnis)) {$ res [] = &row;} echo json_encode ($ res); –