首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >类似之后的MySQL子字符串

类似之后的MySQL子字符串
EN

Stack Overflow用户
提问于 2017-07-20 11:44:10
回答 4查看 80关注 0票数 1

我有一个来自POST命令的变量,它通过会话传递-> $ark = 123456-78

我想把所有的东西都保留在"-“之前,所以123456来做我的研究。

我认为使用Subtring会有效,所以我尝试了如下:

这是我的要求:

代码语言:javascript
运行
复制
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE('$ark')";

我尝试过但没有切除结果:

代码语言:javascript
运行
复制
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE FLOOR('$ark')";

代码语言:javascript
运行
复制
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE SUBSTRING('$ark',6)"

知道我在哪里犯了错吗?

编辑:最后,我找到了使用SUBSTRING_INDEX()的解决方案

代码语言:javascript
运行
复制
$req = "SELECT COUNT(`Home`)FROM `users` WHERE `Home` LIKE SUBSTRING_INDEX('%$ark%','-','1')"; 

谢谢大家的帮助,Rflow

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-07-20 11:50:59

请试试这个。希望它能成功。

代码语言:javascript
运行
复制
$req = "SELECT COUNT(`Home`) FROM `users` WHERE `Home` LIKE concat('%', SUBSTRING('$ark',6), '%')";
票数 1
EN

Stack Overflow用户

发布于 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%'

票数 2
EN

Stack Overflow用户

发布于 2017-07-20 11:46:59

您需要%作为通配符

代码语言:javascript
运行
复制
SELECT COUNT(`Home`) 
FROM `users` 
WHERE `Home` LIKE concat('%', SUBSTRING('$ark',6), '%')
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45213738

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档