PHP查询基于文本输入和下拉选项-并忽略空白


PHP Query based on text input and dropdown option - and ignoring whitespace?

我有一个包含两个表的数据库,两个表都包含邮政编码,即。"SY25 6WB"我已经建立了一个查询,将查询数据库中输入的邮政编码的文本框,如果邮政编码是在数据库中,它做一些jquery -所有工作正常,

我的目标是要做的是,有查询首先基于邮政编码运行,然后如果没有找到,搜索下一个表的邮政编码,如果下拉框填充了一定的值。我也在寻找一种方法来忽略空白,所以如果用户输入"SY256WB"或"SY256WB",它会拉出相同的结果。

我把我的代码粘贴在下面。

形式:

<form action="" method="post">  
Search: <input type="text" name="term" />  
<select name="options">
  <option value="YES">YES</option>
  <option value="NO">NO</option>
</select>
<p>Enter your full postcode with spaces i.e. SA1 3XL</p>
<br />
<input type="submit" value="Submit" />  
</form>  
PHP

<?php
if (!empty($_REQUEST['term'])) {
$term = mysql_real_escape_string($_REQUEST['term']);    
$benefit = mysql_real_escape_string($_REQUEST['YES']);     
$sql = "SELECT * FROM cscopc WHERE POSTCODE LIKE '".$term."'"; 
$r_query = mysql_query($sql);
if ( mysql_num_rows($r_query) > 0 ) {
    echo 'YES';
}
else if ( mysql_num_rows($r_query) == 0 ) {
    $sqltwo = "SELECT * FROM cscowb WHERE PCODE LIKE '".$term."'"; 
    $nextab = mysql_query($sqltwo);
        if ( mysql_num_rows($nextab) > 0 ) {
        echo 'YES WITH OPTION';
    }
        else { 
    echo 'NO';
     }
}
}
?>

如果有人能阐明我如何做到这一点,或指出我在正确的方向为一些参考,这将是非常感激!

使用PDO:

更新了新的查询
        try {
            $conn = new PDO('mysql:host=localhost;dbname=cscoapp', $username, $password);
            $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);    
            } 
        catch(PDOException $e) {
            echo 'ERROR: ' . $e->getMessage();
        }
        $id = $_POST['term'];
        if (!empty($_REQUEST['term'])) {
            $stmt = $conn->prepare('SELECT * FROM cscopc WHERE POSTCODE = :id');
            $stmt->execute(array('id' => $id));
                if ($row = $stmt->fetch(PDO::FETCH_OBJ)) {
                    echo 'YEP';
                }
        else if ($_POST['benefits'] == 'yes') { 
            $stmtwb = $conn->prepare('SELECT * FROM cscowb WHERE POSTCODDE = :id');
            $stmtwb->execute(array('id' => $id));
                if ($row = $stmtwb->fetch(PDO::FETCH_OBJ)) {
                echo 'YEP';
            }
    }
        else {
        echo 'nope';
        }
    }

假设数据库中的邮政编码格式正确(即包含空格),那么您需要对用户输入进行一些验证(无论如何这是一个好主意)。

这里有验证的例子:英国(GB)邮政编码验证没有regex

一旦验证了用户输入,就可以轻松地格式化邮政编码,以便在数据库中查找它。下面是一个简单的例子:

// remove all spaces and upper case
$userInput = strtoupper(preg_replace('/'s+/', '', $_REQUEST['term']));
if (isValidPostcode($userInput)) {
    // Basic postcode formatting - add a space before the last 3 characters
    $formatted = substr($userInput, 0, -3) . ' ' . substr($userInput, -3);
    // now look up in db using $formatted
} else {
    // invalid postcode!
}

但是,如果数据库中的数据不是那么干净,那么您需要找到一种方法:(a)提高数据质量,或者(b)使用正则表达式搜索表:

// create a regex for your lookup: turns 'SA13XL' into 'SA1's*3XL'
$regex = sprintf('%s's*%s', substr($userInput, 0, -3), substr($userInput, -3));
// now look up using the regex
$statement = $db->prepare('SELECT * FROM cscopc WHERE POSTCODE REGEXP :postcode');
$statement->bindParam(':postcode', $regex);
注意:上面的例子使用了PDO,你应该真的考虑使用它,因为mysql_函数已经被弃用了。请看这个问题:为什么我不应该't在PHP中使用mysql_*函数?

可以使用str_replacepreg_replace函数删除每次出现的空格(' ')。我希望您使用str_replace函数。这里我举了一些例子供大家参考。希望这将解决您的疑问。

<?php
$str1="SY25 6WB";
$new=str_replace(' ', '', $str1);
echo "<b>Case I:</b><br>Old String : $str1<br>New String : $new";
$str2="    SY25 6WB   ";
$new=str_replace(' ', '', $str2);
echo "<br><b>Case II:</b><br>Old String : $str2<br>New String : $new";
$str3="SY256WB";
$new=str_replace(' ', '', $str3);
echo "<br><b>Case III:</b><br>Old String : $str3<br>New String : $new";
$str4="   SY256WB    ";
$new=str_replace(' ', '', $str4);
echo "<br><b>Case IV:</b><br>Old String : $str4<br>New String : $new";
?>
/*The output will be -
Case I:
Old String : SY25 6WB
New String : SY256WB
Case II:
Old String : SY25 6WB
New String : SY256WB
Case III:
Old String : SY256WB
New String : SY256WB
Case IV:
Old String : SY256WB
New String : SY256WB
*/