>一/二
>一/二/三
> 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)