选择所有项目 其中 cat_id= x 或 parent_id = x(父 ID 不同表)


Select all items Where cat_id= x or parent_id = x (Parent id different table)

嗨,正如标题所说,我有一个PHP代码,我成功地回显了表中的文章,问题出在这个表中,我只有cat_id parent_id在其他表中被引用。

"articulos" table
id | titulo | fecha_evento | descripcion | img | cat_id
"categoriablog" table
    id | parent_id 

这是我进行查询的方式

$query1 = "SELECT id,titulo,fecha_evento,descripcion,img FROM articulos WHERE cat_id = 1";
    $result = mysql_query($query1);

我的目标是做这样的事情,但"parent_id"在其他表中

$query1 = "SELECT id,titulo,fecha_evento,descripcion,img FROM articulos WHERE cat_id = 1 OR parent_id = 1";
        $result = mysql_query($query1);

JOIN两个表

SELECT 
  a.id, a.titulo, a.fecha_evento, a.descripcion, a.img 
FROM Article AS a 
INNER JOIN Category AS c ON a.cat_id = c.id
WHERE a.cat_id = x
   OR c.parent_id = x

您可以使用子查询

SELECT id,titulo,fecha_evento,descripcion,img FROM Article
 WHERE cat_id = 1 OR cat_id IN
 (SELECT id from Category where parent_id=1)

编辑

请注意,此解决方案比 Mahmoud 回答中的 JOIN 解决方案慢一点。