- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一长串电气设备 list ,其中有一列用于详细信息,其中包含每个电气组件的信息。 (大约 1k 行)。
所以对于 LG,我有这样的详细信息:LG SCREEN 40''
现在我在我的 PHP 页面中有这个查询:
$type = $_REQUEST['type'];
$details = $_REQUEST['details'];
$quantity = $_REQUEST['quantity'];
$price = $_REQUEST['price'];
$update = "SELECT * FROM purchases
WHERE sale_type = :type AND sale_details LIKE %:details%";
$prepUpd = $conn->prepare($update);
$prepUpd->bindValue(':type', $type);
$prepUpd->bindValue(':details', $details);
$prepUpdExec = $prepUpd->execute();
$result = $prepUpd->fetchAll();
我添加 LIKE %:details%
的原因是因为我的客户使用多个空格添加了一些数据,所以我有一些这样的变量:LG LED 32''
(我什至不知道他为什么这样做)当我想选择这种类型的详细信息时,这个空间会出错。
所以使用 %
给我这个错误:
PDOException: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '%'LED SAMSUNG 40\'\'''
而且我认为数据库中的 inches ''
在选择和更新时造成了一些麻烦,因此不胜感激。
他们有什么方法可以去除每个单元格内的多余空间吗?以及如何解决 inches quote '' 的问题,当然还有关于 like % :...
最佳答案
<强>1。使用like
您必须将 %
添加到要查询的值中,而不是添加到您的 sql 语句中。
$details = '%' . $_REQUEST['details'] .'%';
$update = "SELECT * FROM purchases WHERE sale_type = :type AND sale_details LIKE :details";
$prepUpd = $conn->prepare($update);
<强>2。删除空格
最佳解决方案是“规范化”您的类型列。用一个空格替换任何空格序列。这应该在将数据存储在表中时完成。如果没有多个空间,一切都会变得容易得多。
编辑 1:如果您想手动清理数据,可以使用以下 sql 命令
update purchases set sale_type = replace(sale_type,' ',' ');
重复此操作多次,直到不再有行受到查询的影响。
可能您不喜欢这样做...那么让我们看看替代方案。
MySql 提供 replace()
和 trim()
用于字符串替换和删除前导/尾随空格。
trim()
示例:
select trim(' XXX '); # result 'XXX'
这是一个很好的结果并且很有用,但现在问题来了......
replace()
示例
# Replace two spaces by one space
select replace(' XXX ',' ',' '); # result' XXX '
如您所见,这确实会将两个空格替换为一个空格,但结果可能会令人惊讶。输出字符串仍然会有多个空格。
使用多个 replace()
调用以获得更好的结果可能很诱人:
# replace three spaces by one space, than replace two spaces by one space
select replace(replace(' XXX ',' ',' '),' ',' '); # result: ' XXX '
还剩一个空格:-(
您可以在 replace()
中使用尽可能多的 replace()
,您永远不会得到适用于每种情况的解决方案。
结论:这可能在很多情况下都有效,但并非在所有情况下都有效。
如果你仍然想将 replace()
应用到你的代码中,那么可以这样尝试:
$update = "SELECT * FROM purchases
WHERE replace(sale_type,' ',' ') = replace(:type,' ',' ') AND sale_details LIKE %:details%";
编辑 2你可以从 =
切换到 like
// Replace each sequence of spaces with "% %"
$type = preg_replace('/\s+/','% %',$type);
$update = "SELECT * FROM purchases WHERE sale_type like :type AND sale_details LIKE %:details%";
<强>3。以及如何解决inches quote ''的问题
我真的相信您对引号没有问题。使用准备好的语句时,请注意转义这些字符。
关于php - 英寸引号和空格在 MySQL 内部造成麻烦,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34737064/
我已经习惯了 hibernate ,但我时不时地跌跌撞撞,这是另一个。 我正在努力实现以下目标: @OneToMany @JoinTable(name = "inter_spec",
我的 CakePHP 网站几个月来一直运行良好,直到我今天尝试访问它时,出现以下错误: Warning: include(Cake/bootstrap.php): failed to open str
此代码对其他人有效吗?很长一段时间以来,添加事件监听器都不起作用。 Page Title window.onload = init(); function init
我试图在文本中只留下 a-zA-Z0-9._ : $new_pgname=preg_replace('|(^[a-zA-Z0-9_\.])|s','',$new_pgname); 但是你猜怎么着……对
html: [...][...] js [...]alert(document.getElementById("test").name);[...] 为什么我得到的是“undefined”而不是“te
我正在尝试创建一个实现 main 方法的驱动程序类。它必须创建并测试一个对象来演示所有程序功能。 我认为我已经创建了正确的驱动程序类,但我运行的测试证明我的代码中存在错误,这就是我到目前为止所拥有的。
我正在制作一款扑克游戏,但遇到了一个问题,几乎所有事情都可以按照交易按钮的 actionListener 进行。它应该删除交易按钮并添加一个新的 JTextArea (此文本只是一个占位符)。在那之前
我有一些编程经验,但我对 python 很陌生,我正在尝试弄清楚如何使用和导入 .py 文件中的类而不是 main 。我目前正在使用 netbeans,运行 CPython 3.2.1。 根据我现在的
好吧,我不知道发生了什么。我对 iOS 还比较陌生,所以我的调试技能还达不到他们需要的水平。我有一个文本字段工作得很好,直到我在我的应用程序中做了一些更改,这些更改与文本字段没有任何关系(至少我认为它
你好社区我有以下问题。 我的 list 文件如下所示。
我正在使用Drupal2Wordpress plugin将我的内容从 Drupal 传输到 WP,但我在尝试开始该过程时收到此错误:无法连接到 Drupal 数据库。 这是MySQL的日志: 1504
我有以下代码。它编译得很好,但它告诉我字符串是“E#^$$@$$$$$$$”。有什么想法吗? ifstream InFile(Filename); if (!InFile) return fa
我正在为类(class)的期末考试做准备,并且正在尝试重做作业问题。这是我第一次获得零学分的其中之一。 此练习的目标是创建一个 URL,该 URL 将指向包含以下 HTML 的页面,而不是显示预期的协
我开始研究套接字,但遇到了麻烦!我做错了什么? 服务器: /* server.c */ /* ############### INCLUDES ############### */ #include
我正在尝试制作一个逐行读取文件然后将读取的行放入链表的程序,我的问题是将字符串添加到列表中。看代码,在else测试中你可以看到我的问题。 #include #include struct list_e
我是 WordPress 新手,正在为 friend 编辑网站。我正在尝试向站点添加 RSS 提要,因此我编辑了 header.php 文件(这就是它的去向)。 我还编辑了 CSS,然后使用 File
我将向您展示 2 个场景(注意 d=damping factor=0.5) 第一种情况:假设有 4 个节点 A, B, C, D : B、C、D 链接到 A。 PageRank 是:PR(A)=0.5
我无法理解 mem_fun_ref。我必须承认,我通常将仿函数用于此类事情,因为它们可以内联以提高速度和利润。但是,这段代码不会成为瓶颈,所以我想尝试一下。 这是我想做的一个例子。我知道还有其他方法可
尝试使用 AudioClip 编译 applet 时出现预期标识符错误。我计划将其添加到 JFrame,并希望让 AudioClip 循环播放。 import java.applet.*; impor
我正在尝试开始使用 node.js,但我绝不是高级程序员。除了检查我的 ip,我从未使用过 cmd。 我的问题是我不知道将文件保存在哪里,以及如何使用 node.js 从 cmd 运行它们。我发现的教
我是一名优秀的程序员,十分优秀!