从url获取值并在sql查询中使用它

时间:2018-05-05 15:39:48

标签: php jquery sql

我正在为汽车经销商开展一个复杂的项目,我必须根据多个标准创建数据库搜索。数据库中的汽车分为3种类型 - 我们称它们为A,B和C.假设A = 1,B = 2,C = 3的值。该网址看起来像index.php?type_id=1。到目前为止,工作搜索代码如下。

index.php

<script type="text/javascript">
$(document).ready(function(){
    $('#car').on('change',function(){
        var carID = $(this).val();
        if(carID){
            $.ajax({
                type:'POST',
                url:'ajaxData.php',
                data:'marque_id='+carID,
                success:function(html){
                    $('#model').removeAttr("disabled");
                    $('#model').html(html);
                }
            }); 
        }else{
            $('#model').attr("disabled");
            $('#energy').attr("disabled");
        }
    });
});
</script>

$type_id = $_GET['type_id];

$query = $db->query("SELECT DISTINCT marque_name,a.marque_id FROM vehicule_marque as a INNER JOIN vehicule as b WHERE b.type_id = '$type_id' AND a.marque_id = b.marque_id  order by marque_name");
$rowCount = $query->num_rows;

<div>Select car</div>
    <select name="car" id="car" required >
        <option value="">Select Car</option>
        <?php
        if($rowCount > 0){
            while($row = $query->fetch_assoc()){ 
                echo '<option value="'.$row['marque_id'].'">'.$row['marque_name'].'</option>';
            }
        }else{
            echo '<option value="">Car not available</option>';
        }

        ?>
    </select>


    <div>Select car model</div>
    <select name="model" id="model" disabled>
        <option value=""><!--Select car first--></option>
    </select>

ajaxData.php

if(isset($_POST["marque_id"]) && !empty($_POST["marque_id"])) {
    //Get all state data
    $query = $db->query("SELECT DISTINCT a.modele_id, modele_name, a.marque_id FROM vehicule_modele as a INNER JOIN vehicule as b  WHERE a.marque_id = ".$_POST['marque_id']." AND b.type_id = '$type_id' AND b.marque_id = a.marque_id AND b.modele_id = a.modele_id ORDER BY modele_name ");

    //Count total number of rows
    $rowCount = $query->num_rows;

    //Display model list
    if($rowCount > 0){
        echo '<option value="">Select model</option>';
        while($row = $query->fetch_assoc()){
            echo '<option value="'.$row['modele_id'].'">'.$row['modele_name'].'</option>';
        }
    }else{
        echo '<option value="">Model not available</option>';
    }
}

问题在于获取type_id值并在ajaxData.php查询中使用它,以便在客户选择汽车品牌后显示模型。在index.php中,我GET来自网址的值成功(我尝试回应它并且它有效),但后来我无法让它在其他查询中工作 - 它一直只显示“型号不可用“选项。我尝试将$type_id内的脚本放入一个新变量中,但这也不起作用。我不确定我错过了什么。如果我删除type_id条件,一切都很完美。如果有人知道如何解决这个问题,我将不胜感激。

1 个答案:

答案 0 :(得分:0)

首先,您需要了解对网址index.php?type_id=1和网址ajaxData.php的请求是不同的请求,并且知道没有彼此。

因此,如果您尝试访问$_GET['type_id']中的ajaxData.php显然会接收,因为$_GET ajaxData.php中排空。如果您向ajaxData.php?type_id=42发送请求,则将<{strong> 42作为$_GET['type_id']

因此,如果您想在$_GET中使用某些$_POSTajaxData.php数据,必须明确发送此数据

可以是:

url:'ajaxData.php?type_id=' + yourValue,  
// access it with $_GET['type_id']

data:'marque_id='+carID+'&type_id='+yourValue,
// access it with $_POST['type_id']