我有一个包含两个表的数据库,两个表都包含邮政编码,即。"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_replace或preg_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
*/