我正在使用
PHP和MySQL构建社交媒体新闻聚合Web应用程序.它需要将各种URL(列url)映射到特定趋势(列trend_id).这是我的虚拟数据结构:
我需要构建一个查询来获取特定trend_id的URL(例如12).这很简单:
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(父项).这是关系表的快照:
最佳答案 您现在的具体查询是:
SELECT r.trend_id as parent_trend_id,url
FROM url_table
Join relations r on r.related_trend_id = childid
WHERE r.trend_id = 12
或者得到所有这些
SELECT r.trend_id as parent_trend_id,url
FROM url_table
Join relations r on r.related_trend_id = childid
完全按照我的预期工作:
http://sqlfiddle.com/#!3/b137a/9
你期望得到什么结果?