使用模式双重插入数据

时间:2019-04-29 07:54:07

标签: php jquery mysql ajax

我正在研究PHP + MYSQL + AJAX项目。添加数据时,我使用了Bootstrap Modal。第一次单击添加后,它将插入两个记录,但是仅在第一次单击时发生。

有什么办法可以防止保存两条记录。

感谢您的帮助和建议。谢谢

这是我的模态

<div id="userModal" class="modal fade">
<div class="modal-dialog">
    <form method="post" id="user_form" enctype="multipart/form-data" class="form-horizontal">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal">&times;</button>
                <h4 class="modal-title">Add User</h4>
            </div>
            <div class="modal-body">

                <div class="form-group">
                    <label class="col-lg-3 control-label">Name</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sName" maxlength="150" id="sName" placeholder="Enter your Name" />  
                        <span id='remainingC'></span>                
                    </div>
                </div>


                <div class="form-group">
                    <label class="col-lg-3 control-label">Username</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sUsername" maxlength="20" id="sUsername" placeholder="Enter your Username"/>   
                        <span id='remainingCu'></span>                
                    </div>
                </div>

                <div class="form-group">
                    <label class="col-lg-3 control-label">Birthday</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sBirthday" 
                        onchange ="getAge();" maxlength="20" id="sBirthday" placeholder="YYYY-mm-dd"/>                                       
                    </div>
                </div>

                <div class="form-group">
                    <label class="col-lg-3 control-label">Age</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="iAge" maxlength="3" id="iAge" placeholder="Autofill when you fill Birthday"/>                                          
                    </div>
                </div>

                <div class="form-group">
                    <label class="col-lg-3 control-label">Email</label>
                    <div class="col-lg-9">
                        <input type="text" class="form-control" name="sEmail" id="sEmail" placeholder="Enter your Email - eg. jb@gmail.com"/>                                        
                    </div>
                </div>

我的AJAX请求

$(document).ready(function(){
$('#add_button').click(function(){
    $('#user_form')[0].reset();
    $('.modal-title').text("Add User");
    $('#action').val("Add");
    $('#operation').val("Add");
    // $('#user_uploaded_image').html('');
});

var dataTable = $('#user_data').DataTable({
    "processing":true,
    "serverSide":true,
    "order":[],
    "ajax":{
        url:"fetch.php",
        type:"POST"
    },
    "columnDefs":[
        {
            "targets":[0, 3, 4],
            "orderable":false,
        },
    ],

});

$(document).on('submit', '#user_form', function(event){
    event.preventDefault();
    var sName = $('#sName').val();
    var sUsername = $('#sUsername').val();
    var sBirthday = $('#sBirthday').val();
    var iAge = $('#iAge').val();
    var sEmail = $('#sEmail').val();

    if(sName != '' && sUsername != '' && sBirthday != '' && iAge != '' && sEmail != '')
    {
        $.ajax({
            url:"insert.php",
            method:'POST',
            data:new FormData(this),
            contentType:false,
            processData:false,
            success:function(data)
            {
                alert(data);
                $('#user_form')[0].reset();
                $('#userModal').modal('hide');
                dataTable.ajax.reload();
            }
        });
    }
    else
    {
        alert("Both Fields are Required");
    }
});

这是我添加(insert.php)的功能

if($_POST["operation"] == "Add")
{
    $statement = $connection->prepare("
        INSERT INTO users (sName, sUsername, sBirthday, iAge, sEmail) 
        VALUES (:sName, :sUsername, :sBirthday, :iAge, :sEmail)
    ");
    $result = $statement->execute(
        array(
            ':sName'    =>  $_POST["sName"],
            ':sUsername'    =>  $_POST["sUsername"],
            ':sBirthday'    =>  $_POST["sBirthday"],
            ':iAge' =>  $_POST["iAge"],
            ':sEmail'   =>  $_POST["sEmail"]

        )
    );
    if(!empty($result))
    {
        echo 'Data Inserted';
    }
}

在模式中第一次单击添加按钮后,复制数据: Duplicate

0 个答案:

没有答案
相关问题