簡體   English   中英

從同一表的兩個不同列中選擇DISTINCT值

[英]SELECTING DISTINCT values from two different COLUMNS of the same table

我有一個SQL表看起來像這樣。

id     name     cname
1      Ash      abc       
2      Ash      abc
3      Ashu     abc
4      Ashu     xyz
5      Yash     xyzz
6      Ash      xyyy

我希望用戶從顯示DISTINCT名稱值及其正常工作的第一個選擇下拉列表中選擇一個值。

第一選擇:

<select id="select1" required="required" class="custom-select standard">
<option value="0" selected="selected">Choose Category</option>
<?php 
    $resultd = mysqli_query($mysqli,"SELECT DISTINCT name FROM advertise");
    if ($resultd)
        {
              while($tier = mysqli_fetch_array($resultd)) 
                {
                    echo '<option value="' .$tier['name'] . '">' . $tier['name'] . '</option>';
                }
        }
?>
</select>

現在我想顯示基於第一個的第二個選擇下拉框的值。 我為此使用的jQuery是:

<script>
    $(function(){
    var conditionalSelect = $("#select2"),
    // Save possible options
    options = conditionalSelect.children(".conditional").clone();

    $("#select1").change(function(){
    var value = $(this).val();                  
    conditionalSelect.children(".conditional").remove();
    options.clone().filter("."+value).appendTo(conditionalSelect);
}).trigger("change");
});
</script>

第二選擇框

<select id="select2" required="required" class="custom-select standard">
<option value="0" selected="selected">Choose Location</option>
<option class="conditional name" value="">cname</option>
</select>

我只想知道什么是PHP查詢,我需要使用它來在基於第一個的第二選擇框中獲取值。 我做了很多嘗試來找到解決方案,但是我沒有找到任何可以從數據庫中獲取其值的解決方案...在此先感謝...

如果您做的事情有所不同,則可能不需要第二查詢和所有這些復雜性。 這意味着,您可以使用一個查詢來實現您的目標。 下面的代碼演示了如何。 注意:此解決方案使用JQuery使事情變得更簡單。

為了測試 只需將Code IS IS IS 復制並粘貼 到新文件中,然后查看其是否按預期工作。

干杯和好運!

<?php

    // USE YOUR CONNECTION DATA... PDO WOULD BE HIGHLY RECOMMENDED.
    // INTENTIONALLY USING mysqli (NOT RECOMMENDED) TO MATCH YOUR ORIGINAL POST.
    $conn       = mysqli_connect("localhost", "root", 'root', "test");
    if (mysqli_connect_errno()){
        die("Failed to connect to MySQL: " . mysqli_connect_error());
    }

    $resourceID = mysqli_query($conn, "SELECT * FROM advertise");
    $all        = mysqli_fetch_all($resourceID, MYSQLI_ASSOC);
    $uniques    = [];
    $options1   = "";

    if( !empty($all) ){
        foreach($all as $intKey=>$advertiseData) {
            $key    = $advertiseData['name'];
            $cName  = getCNameForName($all, $key);
            if (!array_key_exists($key, $uniques)) {
                $uniques[$key] = $advertiseData;
                $options1 .= "<option value='{$key}' data-cname='{$cName}'>";
                $options1 .= $key . "</option>";
            }
        }
    }

    function getCNameForName($all, $name){
        $result = [];
        foreach($all as $iKey=>$data){
            if($data["name"] == $name){
                $result[] = $data['cname'];
            }
        }
        return $result ? implode(", ", array_unique($result)) : "";
    }
?>

<html>
<body>
<div>
    <select id="select1" required="required" class="custom-select standard">
        <option value="0" selected="selected">Choose Category</option>
        <?php echo $options1; ?>
    </select>
    <select id="select2" required="required" class="custom-select standard">
        <option value="0" selected="selected">Choose Location</option>
    </select>
</div>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
<script type="text/javascript">

    (function($) {
        $(document).ready(function(){
            var firstSelect     = $("#select1");
            var secondSelect    = $("#select2");

            firstSelect.on("change", function(){
                var main        = $(this);
                var mainName    = main.val();
                var mainCName   = main.children('option:selected').attr("data-cname");
                var arrCName    = mainCName.split(", ");
                var options2    = "<option value='0' selected >Choose Location</option>";

                for(var i in arrCName){
                    options2   += "<option value='" + arrCName[i]  + "' ";
                    options2   += "data-name='" + mainName + "'>" + arrCName[i] + "</option>\n";
                }

                secondSelect.html(options2);
            });

        });
    })(jQuery);
</script>

</body>
</html>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM