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)

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...