我在这个问题中读到了类似的答案:如何从多个$_POST数组插入到MYSQL行,以及如何从多个子$_POST阵列插入到MYSQL行,但问题是这些答案在我的代码中不起作用。是因为我使用ajax吗?我只得到第一个数组的值。
如果我也将变量声明放在for循环中,它也不起作用。
这是我的ajax:
var name = [];
$('input[name="name[]"]').map(function(){ name.push($(this).val()); }); var studid = [];
$('input[name="studid[]"]').map(function(){ studid.push($(this).val()); }); var nameStr = name != '' ? '&name='+ name : '';
var studStr = studid != '' ? '&studid='+ studid : '';
var dataString = 'subject='+ subject + '§ion=' + section + studStr + nameStr;
$.ajax({ type: "POST", url: 'save.php', data: dataString, dataType: "html",
success: function(data) {
$('input#subject-field').val('');
$('input#section-field').val('');
$('input.record-input-forms').val('');
$('#status-message').css({"color":"#39b1c6"});
$('#status-message').html('Save successfully',function(){
$('#status-message').fadeOut(2000); }); },
error:function (xhr, ajaxOptions, thrownError){
alert(thrownError); } });
return false;
});
这是我的php:
if(isset($_POST['studid']) || isset($_POST['name'])){
$studid = array_map(mysql_real_escape_string, explode(",",$_POST['studid']));
$name = array_map(mysql_real_escape_string, explode(",",$_POST['name']));
for ($i=0; $i<count($studid); $i++){
$sql_1 = "INSERT INTO tbl_student(StudentID, StudentName, SubjectID) VALUES ('".$studid[$i]."', '".$name[$i]."', LAST_INSERT_ID())";
mysqli_query($con,$sql_1);
}
}
使用mysql_insert_id();而不是LAST_INSERT_ID()
您没有正确地从jQuery发送数据,而且似乎将数组和字符串混合在一起。
这是一个简单的请求,从jQuery 发布研究过的数组
var saveData = $.ajax({
type: 'POST',
data: {studid: studid},
url: 'save.php',
dataType: 'html'
});
saveData.done(function(data) {
$('input#subject-field').val('');
$('input#section-field').val('');
$('input.record-input-forms').val('');
$('#status-message').css({"color":"#39b1c6"});
$('#status-message').html('Save successfully',function(){
$('#status-message').fadeOut(2000); });
});
saveData.fail(function(ts) {
alert(ts.responseText);
});
调用save.php时,将设置$_POST['studid']
(如果数组中有任何内容)
如果你喜欢这样做:
var saveData = $.ajax({
type: 'POST',
url: 'save.php?studid=' + studid,
dataType: 'html'
});
调用save.php时,将设置$_GET['studid']
(如果数组中有任何内容)。不过,最好的方法是在ajax函数调用中使用data选项(在我的第一种情况下)。如果选择使用此选项,则必须先序列化stuid数组,然后将其作为url的一部分放入。
更新如果你想传递多个数组,你必须这样做:
var saveData = $.ajax({
type: 'POST',
data: {studid: studid, name_arr2: data_arr2},
url: 'save.php',
dataType: 'html'
});