我有一个来自POST命令的变量,它通过会话传递-> $ark = 123456-78
我想把所有的东西都保留在"-“之前,所以123456来做我的研究。
我认为使用Subtring会有效,所以我尝试了如下:
这是我的要求:
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE('$ark')";我尝试过但没有切除结果:
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE FLOOR('$ark')";和
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE SUBSTRING('$ark',6)"知道我在哪里犯了错吗?
编辑:最后,我找到了使用SUBSTRING_INDEX()的解决方案
$req = "SELECT COUNT(`Home`)FROM `users` WHERE `Home` LIKE SUBSTRING_INDEX('%$ark%','-','1')"; 谢谢大家的帮助,Rflow
发布于 2017-07-20 11:50:59
请试试这个。希望它能成功。
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE concat('%', SUBSTRING('$ark',6), '%')";发布于 2017-07-20 13:44:44
如果提供LIKE子句时没有通配符,那么它的工作方式就像等于操作符一样。
所以当你尝试
where home LIKE SUBSTRING('$ark',6),就像
where home = '123456',这在您的情况下不是真的。
因此,您必须使用通配符来匹配数据。
where home LIKE concat('%', SUBSTRING('$ark',6), '%') (如果您知道123456不在中间,可以跳过前面的%),它等于
where home LIKE '%123456%'
发布于 2017-07-20 11:46:59
您需要%作为通配符
SELECT COUNT(`Home`)
FROM `users`
WHERE `Home` LIKE concat('%', SUBSTRING('$ark',6), '%')https://stackoverflow.com/questions/45213738
复制相似问题