>一/二
>一/二/三
> 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 举报,一经查实,本站将立刻删除。