微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – MySQL UNION SELECT直到找到?

假设我有一个带有’URL’列的表,我就像这样存储url

>一/二
>一/二/三
> alpha / omega

我想从数据库获取特定网址的数据,如果找不到,我会删除网址的最后一部分并再次搜索

例:

我的网址像一个/两个/三个/四个/五个.

搜索“一/二/三/四/五”

如果没有找到再次搜索“一/二/三/四”

如果没有找到再次搜索“一/二/三”

如果没有找到再次搜索“一/二”

我希望有类似的东西:

SELECT * FROM db WHERE url=one/two/three/four/five

UNION

SELECT * FROM db WHERE url=one/two/three/four/five

UNION

SELECT * FROM db WHERE url=one/two/three/four

UNION

SELECT * FROM db WHERE url=one/two/three

UNION

SELECT * FROM db WHERE url=one/two

UNION

SELECT * FROM db WHERE url=one

但是我想停止搜索是否找到了行.

这是可能的,还是必须使用分开的查询来完成.

感谢帮助.

解决方法:

我觉得这是你问题最优雅的方法.此语句是独立的深度路径,您不需要在后续选择中拆分常量URL:

SELECT 
   * 
FROM 
   db 
WHERE 
   concat( 'one/two/three/four/five' , '/') like concat( url , '/%')
ORDER BY
   LENGTH (url) desc
LIMIT 1

我在MysqL中测试了这个查询,也是you can check it! (in MSSQL syntax)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐