当前位置: 首页 > 面试题库 >

MySQL-加入a或b

方璞
2023-03-14
问题内容

假设我有一个TABLE a,其中aCOLUMN data是要 加入 另外2个表(TABLE bTABLE c)的一个COLUMNinfo,因为我想获得inbc
事情是a.data将匹配 b.data 或只能c.data

  • 我如何获得b.infoc.info基于a

我尝试了多远:

经过多次尝试使用明显错误的语法后,我所做的最好的事情是在两个查询中:

SELECT b.info FROM a INNER JOIN b ON a.data = b.data
SELECT c.info FROM a INNER JOIN c ON a.data = c.data

我想实现一些可能看起来像这样的东西:

SELECT alias.info FROM a INNER JOIN (b OR c) AS alias ON a.data = alias.data

我为什么要这样做

实际上,我可以获取所需的数据并使用PHP进行处理。但是我要进行一个庞大的过程(与我的问题无关),而不是进行良好的查询,并且该页面需要太多时间来加载。


问题答案:

您可以将,bc表都保留为联接,然后使用info不是的任何字段NULL

select coalesce(b.info, c.info) info
from a
  left join b on a.data = b.data
  left join c on a.data = c.data


 类似资料:
  • 问题内容: 几个月前,我和其他人一起用PHP编写了一个简单的应用程序。在那里,我们需要根据一个用户ID和您需要从该用户ID选择的行中获取的另一个值,从多个表中执行SELECT。 我的第一个想法是创建多个SELECT并解析PHP脚本中的所有输出(使用所有mysql_num_rows()和类似的函数进行检查),但是那个家伙告诉我他会这样做。“好的没问题!” 我想,我的写作要少得多。好吧,当我发现他只用

  • 问题内容: 我有两个要加入的表。 我想要类别表中的所有类别以及用户在category_subscriptions表中订阅的所有类别。 基本上这是我到目前为止的查询: 这很好用,但是我想在查询的末尾添加一个where子句,然后从本质上使它成为一个内部/等参连接。 如何仅使用一个查询获取所有类别以及特定用户订阅的所有类别? category_id是类别表和user_category_subscript

  • 问题内容: 假设我有两个表一对一的关系。 而且,我想从每个主记录中选择列,并从相关表中选择第一个记录。 我尝试了一些方法,但没有成功…… 在这里,我结束了这个SQL提琴: http://sqlfiddle.com/#!2/39fdb/3 那里的问题是它不能从子选择中引用a.ID。 当然,这行不通,但这只是我能想到的 关于如何解决它的任何想法? 问题答案: 不可以,您无法在与相连的子选择中进行引用。

  • 问题内容: 有没有办法像在MySQL服务器上那样批量执行查询? 将无法使用,因为如果该字段已经存在,它将直接忽略该字段并且不插入任何内容。 将无法工作,因为如果该字段已经存在,它将首先对其进行处理,然后再次进行处理,而不是对其进行更新。 可以使用,但不能批量使用。 因此,我想知道是否可以批量发出这样的命令(一次不止一次发送)。 问题答案: 您 可以 使用INSERT … ON DUPLICATE

  • 问题内容: public void push(E element) { if (size == elements.length) { resize(); // doubel of size } elements[size++] = element; } Java中的a 和 a或a–和–a有什么区别 谢谢 问题答案: 或是后缀运算符,表示a的值将在对表达式求值后更改。 或是前缀运算,表示a的值将在对

  • 问题内容: 一个供您所有MySQL专家使用的技巧:-) 我有以下查询: 订单表= 80,900行 产品表= 125,389行 o.id和p.order_id已建立索引 该查询大约需要6秒钟才能完成-太长了。我正在寻找一种优化它的方法,可能使用临时表或其他类型的联接。恐怕我对这两个概念的理解还很有限。 谁能建议我优化此查询的方法? 问题答案: 首先,我将使用其他样式的语法。 已经有20年的睡眠时间了