我正在用PHP和MySQL构建一个社交媒体新闻聚合Web应用程序。它需要将各种URL(列URL)映射到特定的趋势(列trend_id)。这是我的虚拟数据结构:
我需要构建一个查询,以获取特定trend_id(例如12)的URL。这很简单:
SELECT
url
FROMurl_table
WHEREtrend_id
= '12'
现在,一些趋势与特定的父趋势相关联。例如,trend_ids 12、16和45与父trend_id 12相关联。所以这是我的查询:
SELECT '12' as
parent_trend_id
,url
FROMurl_table
WHERE (trend_id
= '12' ORtrend_id
= '16' ORtrend_id
= '45')
这是另一个类似查询的例子:
SELECT '345' as
parent_trend_id
,url
FROMurl_table
WHERE (trend_id
= '345' ORtrend_id
= '457' ORtrend_id
= '16')
问题在于,趋势之间存在多个这样的父子关系。目前我在PHP中运行一个for循环,并执行多个查询。另外,鉴于我的应用程序的性质,父趋势不能成为此表的一部分。是否有一种方法可以将多个这样的查询合并为单个查询?
编辑:
我有一个单独的表来定义关系。它是一个简单的3列表,包括ID、trend_id(父)和related_trend_id(子)。然而,一个related_trend_id(子)可以有多个trend_ids(父)。以下是关系表的快照: