加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 将多个查询的行组合成一个

发布时间:2020-12-13 16:17:31 所属栏目:PHP教程 来源:网络整理
导读:我正在使用 PHP和MySQL构建社交媒体新闻聚合Web应用程序.它需要将各种URL(列url)映射到特定趋势(列trend_id).这是我的虚拟数据结构: 我需要构建一个查询来获取特定trend_id的URL(例如12).这很简单: SELECT url FROM url_table WHERE trend_id = ’12’ 现
我正在使用 PHP和MySQL构建社交媒体新闻聚合Web应用程序.它需要将各种URL(列url)映射到特定趋势(列trend_id).这是我的虚拟数据结构:

我需要构建一个查询来获取特定trend_id的URL(例如12).这很简单:

SELECT url FROM url_table WHERE trend_id = ’12’

现在,一些趋势与特定的父趋势有关.例如,trend_ids 12,16和45与父trend_id 12相关.所以这是我的查询:

SELECT ’12’ as parent_trend_id,url FROM url_table WHERE (trend_id = ’12’ OR trend_id = ’16’ OR trend_id = ’45’)

这是类似查询的另一个例子:

SELECT ‘345’ as parent_trend_id,url FROM url_table WHERE (trend_id = ‘345’ OR trend_id = ‘457’ OR trend_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

你期望得到什么结果?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读