首页 > 解决方案 > 从 url 获取值并在 sql 查询中使用它

问题描述

我正在为一家汽车经销商开发一个复杂的项目,我必须根据多个条件创建数据库搜索。数据库中的汽车分为 3 种类型——我们称它们为 A、B 和 C。假设 A=1、B=2、C=3 的值。url 看起来像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.phpindex.php中,我GET成功地从 url 中获取了值(我尝试回显它并且它有效),但是我无法让它在另一个查询中工作 - 它继续只显示“模型不可用”选项。我尝试将脚本$type_id放入一个新变量中,但这也不起作用。我不确定我错过了什么。如果我删除 type_id 条件,一切正常。如果有人知道如何解决这个问题,我将不胜感激。

标签: phpjquerysql

解决方案


首先,您需要了解对 url的请求和index.php?type_id=1对 url的请求ajaxData.php不同的请求,彼此一无所知。

因此,如果您尝试访问$_GET['type_id']inajaxData.php显然不会收到任何信息,因为. 如果您向您发送请求,您获得.$_GETajaxData.phpajaxData.php?type_id=42 42$_GET['type_id']

所以,如果你想使用一些$_GET$_POST数据,ajaxData.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']

推荐阅读