如何使用ajax的POST方法使用多数组将数据插入数据库:


How to insert data to database using multiple array using POST method with ajax:

我在这个问题中读到了类似的答案:如何从多个$_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 + '&section=' + 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'
                    });