如果数组中已存在值,则在PHP

时间:2016-02-08 11:03:17

标签: php mysql arrays bootstrap-modal

我有一个代码,其中检查数组中是否已存在值。基本上,程序所做的是它首先将所有值存储在数组中。然后使用count(array_keys)函数检查它。有三个输入。如果在这3个输入中,值出现两次或三次,则会发出错误。现在,我的问题是,如果输入A和输入B是相同但输入C是不同的,它仍将添加到数据库,但如果输入A和C是相同但输入B不同然后它将不添加(其中是对的。)

这是我的php代码:

<?php
include 'config.php';
if(isset($_POST['update_actual_lupong'])){
    $id = isset($_GET['id'])? $_GET['id'] : "";
    $id_hearing = $_POST['hearing_lup'];
    $lupong = $_POST['act_lupong'];
    $actual = array();

    foreach($lupong as $aaa) {
            $actual[] = $aaa;
    }

    if ((count(array_keys($actual, $aaa)) > 1)) { 
            echo '<br><br>this array contains DUPLICATE <br><br>';
    }
    else {

        foreach ($lupong as $lup) {
            $updateMemo = mysqli_query($conn, "INSERT INTO actuallupong(Hearing_idHearing, bar_pos2) VALUES ('$id_hearing', (SELECT idtable_position FROM table_position WHERE Person_idPerson = '$lup'));");
        }

        echo "ADDED ggg";
    }

    //header ('location: view_case_profile.php?id='.$id);
    mysqli_close($conn);
}   
?>

HTML代码(它是一个模态):

<div class="modal fade bs-example-modal-lg" id="modal_lupong" data-backdrop="static" data-keyboard="false" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" >
<div class="modal-dialog modal-lg">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal">
                <span aria-hidden="true">&times;</span>
                <span class="sr-only">Close</span>
                </button>
                <h4 class="modal-title" id="myModalLabel">Update Lupong</h4>
            </div>
        <form id="update_actual_lupong" class="form-horizontal form-label-left calender" name = "update_actual_lupong" enctype="multipart/form-data" method="post" role="form" novalidate>
            <div class="modal-body">
                <div class="d item form-group">
                    <label class="col-sm-3 control-label">Hearing Number</label>
                        <div class="col-sm-7">
                            <input type="number" class="form-control" id="hearing_lup" name="hearing_lup" readonly="readonly"/>
                        </div>
                </div>
            <div class="f item form-group" id = "act1">
                <label class="control-label col-md-3 col-sm-3 col-xs-12">Lupong 1 <span class="required">*</span></label>
                <div class="col-sm-7">
                    <input name="actlupong[]" id="search_keyword_id_act" class="search_keyword_act form-control col-md-7 col-xs-12" required="required" placeholder ="Search first name or last name... " type="text">
                        <input type="hidden" name="act_lupong[]" id="act_lup1"/>
                        <div id="result3"></div>
                </div>
        </div>

        <div class="f item form-group" id = "act2">
            <label class="control-label col-md-3 col-sm-3 col-xs-12">Lupong 2 <span class="required">*</span></label>
                <div class="col-sm-7">
                    <input name="actlupong[]" id="search_keyword_id_act1" class="search_keyword_act1 form-control col-md-7 col-xs-12" required="required" placeholder ="Search first name or last name... " type="text">
                    <input type="hidden" name="act_lupong[]" id="act_lup2"/>
                <div id="result4"></div>
            </div>
        </div>

        <div class="f item form-group" id = "act3">
            <label class="control-label col-md-3 col-sm-3 col-xs-12">Lupong 3 <span class="required">*</span></label>
                <div class="col-sm-7">
                    <input name="actlupong[]" id="search_keyword_id_act2" class="search_keyword_act2 form-control col-md-7 col-xs-12" required="required" placeholder ="Search first name or last name... " type="text">
                    <input type="hidden" name="act_lupong[]" id="act_lup3"/>
                    <div id="result5"></div>
                </div>
            </div>

        </div>
            <div class="modal-footer" style="margin:0;">
                <button type="button" class="btn btn-default" data-dismiss="modal" style="margin-top: 4px;">Close</button>
                <button id="send" type="submit" class="btn btn-success" name="update_actual_lupong">Save Record</button>
        </div>
    </form>
    </div>
    </div>
    </div>

截图: enter image description here

我的代码中出现了什么问题?我应该改变哪一部分?非常感谢您的帮助。谢谢。

2 个答案:

答案 0 :(得分:4)

正如您所说: - There are three inputs. If in those 3 inputs, a value occurs twice or thrice, it will issue an error.

需要对您的代码进行一些修改: -

<?php
include 'config.php';
if(isset($_POST['update_actual_lupong'])){
    $id = isset($_GET['id'])? $_GET['id'] : "";
    $id_hearing = $_POST['hearing_lup'];
    $lupong = $_POST['act_lupong'];
    if (count(array_unique($lupong)) < count($lupong))) {  // check that count of unique $lupong and original $lupong is equal or not if not then $lupong have duplicate values
            echo '<br><br>this array contains DUPLICATE <br><br>';
    }
    else {

        foreach ($lupong as $lup) {
            $updateMemo = mysqli_query($conn, "INSERT INTO actuallupong(Hearing_idHearing, bar_pos2) VALUES ('$id_hearing', (SELECT idtable_position FROM table_position WHERE Person_idPerson = '$lup'));");
        }

        echo "ADDED ggg";
    }

    //header ('location: view_case_profile.php?id='.$id);
    mysqli_close($conn);
}   
?>

答案 1 :(得分:4)

您以$ aaa作为c的值退出循环,因此只检查此值是否有重复。

您应检查循环内的重复项并设置变量,即

$dup = false;
    foreach($lupong as $aaa) {
            $actual[] = $aaa;
            if ((count(array_keys($actual, $aaa)) > 1)) {
                $dup = true;
            } 
    }

if ($dup) { 
        echo '<br><br>this array contains DUPLICATE <br><br>';
}
else {

    foreach ($lupong as $lup) {
        $updateMemo = mysqli_query($conn, "INSERT INTO actuallupong(Hearing_idHearing, bar_pos2) VALUES ('$id_hearing', (SELECT idtable_position FROM table_position WHERE Person_idPerson = '$lup'));");
    }

    echo "ADDED ggg";
}