- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含两个表的数据库,两个表都包含 zip ,即“SY25 6WB” ,它执行一些 jquery - 一切正常,
我打算做的是,首先根据邮政编码运行查询,然后如果找不到,则在下一个表中搜索邮政编码(如果下拉列表中填充了特定值)。我也在寻找一种忽略空格的方法,因此如果用户输入“SY256WB”或“SY25 6WB”,它会得到相同的结果。
我已经在下面粘贴了我的代码。
表格:
<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';
}
}
最佳答案
假设数据库中的邮政编码格式正确(即包含空格),那么您需要对用户输入进行一些验证(无论如何这是个好主意)。
这里有验证的例子:United Kingdom (GB) postal code validation without 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_
函数已被弃用。看到这个问题:Why shouldn't I use mysql_* functions in PHP?
关于基于文本输入和下拉选项的 PHP 查询 - 忽略空格?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24000494/
我有这个代码来查找这个模式:201409250200131738007947036000 - 1,在文本内 final String patternStr = "(\\d{
我正在尝试使用正则表达式清除一些用户输入,以删除 [ 和 ] 并删除任何大于 1 个空格的空格。但我似乎无法实现我想要的效果。这是我第一次使用正则表达式,所以我对如何写出来有点困惑。 (preg_re
我正在尝试构建这个简单的正则表达式来匹配 Java 中的单词+空格,但我在尝试解决它时感到困惑。该网站上有很多类似的示例,但答案大多给出了正则表达式本身,而没有解释它是如何构造的。 我正在寻找的是形成
好吧,我已经阅读了很多建议如何消除多余空间的帖子,但无论出于何种原因,我似乎无法将这些建议应用到我的系统中,所以我在这里寻求您的帮助。 这些是我代码的最后几行: for line in rli
所以我正在我的测试存储上学习网页抓取,但我不确定如何正确地从“sizes”数组中删除空的新行。 const $ = cheerio.load(body) $('div.lis
这个问题已经有答案了: How to prevent invalid characters from being typed into input fields (8 个回答) 已关闭 9 年前。 是
有人知道如何让扫描仪忽略空间吗?我想输入名字和第二个名字,但扫描仪不让我输入,我想保存全名 String name; System.out.print("Enter name: "); name =
这个问题在这里已经有了答案: Make Vim show ALL white spaces as a character (23 个回答) 关闭 8 年前。 VIM(使用 Solarized Dar
我想使用 StreamTokenizer 从 java 文件中提取名称。我已将空格设置为逗号 inputTokenizer.whitespaceChars(',', ','); 但是,
我正在使用此代码逐行读取 txt 文件。 // Open the file that is the first command line parameter FileInputStream fstre
我似乎无法弄清楚我需要的正则表达式。这就是我想要实现的目标: {ANY CHAR} + @javax.persistence.Column(name = "{ANY 30 CHARS}") + {AN
我正在运行 StyleCop(顺便说一句,如果你想提供高质量的代码,我完全推荐它)... 我有这条线 [System.Xml.Serialization.XmlRootAttribute(Namesp
我刚刚更新到 PhpStorm 2016,我突然注意到,每次我按 Ctrl + S 保存文件时,它都会删除我在测试这段代码后按下以继续编写的空格/制表符。 请帮忙,这对我来说很烦人,因为我在每一行代码
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 Improve th
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度的了解。包括尝试的解决方案、为什么它们不起作用以及预期结果
我已经看过几十个关于这个主题的问题和答案,但我仍然无法解决我的问题。 我在我的代码中使用了一个外部 ffmpeg 转换器,我将文件路径作为参数传递,如下所示: OutputPackage oo = c
谁能详细解释一下它们是什么以及它们之间的区别。提前致谢。 最佳答案 转义序列是代表其他内容的字符序列。例如(“\n” = 新行,“\?” = 问号等)。有关更详细的列表,请检查:https://en.
我无法从我的 javascript 文本中删除换行符。这是我正在处理的数据示例: 0: "Christian Pulisic" 1: "↵" 2: "From Wikipedia, the free
我有一个问题 - 我似乎无法从字符串的开头/结尾删除新行/空格。我在正则表达式的开头和结尾使用 \s ,甚至在获取字符串后使用 .trim() ,但无济于事。 public void extractI
我是 php 的新手,我正在尝试将一系列变量添加到 html 超链接中。但是,任何返回空格的变量都会弄乱超链接。 Grants Test
我是一名优秀的程序员,十分优秀!