将两个单独的SQL查询的结果与"OR"组合在一起

Pas*_*ted 1 sql postgresql

框架:Rails 2.3.8数据库; PostgreSQL的

我目前有以下SQL语句(由Rails生成)

SELECT "outbreaks".* FROM "outbreaks" INNER JOIN "bacterial_agents" ON bacterial_agents.outbreak_id = outbreaks.id INNER JOIN "bacteria" ON "bacteria".id = "bacterial_agents".bacterium_id WHERE (bacteria.name ILIKE E'%VTEC O157%')

SELECT "outbreaks".* FROM "outbreaks" INNER JOIN "viral_agents" ON viral_agents.outbreak_id = outbreaks.id INNER JOIN "virus" ON "virus".id = "viral_agents".virus_id WHERE (virus.name ILIKE E'%NOROVIRUS%')
Run Code Online (Sandbox Code Playgroud)

使用下面的表(我已经跳过了未使用的属性,并且布局/键命名归结为Rails约定)

outbreaks
  id

bacterial_agents
  id
  outbreak_id
  bacterium_id

bacteria
  id
  name

viral_agents
  id
  outbreak_id
  virus_id

viruses
  id
  name
Run Code Online (Sandbox Code Playgroud)

任何想法如何加入上述两个带有"OR"条件的SQL语句,以选择与细菌表相关的爆发记录,其中的细菌名称就像"VTEC O157"或与病毒表中的病毒相关.名字就像"NOROVIRUS"?

*编辑

升级关于SQL的Rails生成的澄清 - 它当前输出以下SQL

SELECT "outbreaks".* FROM "outbreaks" INNER JOIN "bacterial_agents" ON bacterial_agents.outbreak_id = outbreaks.id INNER JOIN "bacteria" ON "bacteria".id = "bacterial_agents".bacterium_id INNER JOIN "viral_agents" ON outbreaks.id = viral_agents.outbreak_id INNER JOIN "viruses" ON "viral_agents".virus_id = "viruses".id WHERE ((bacteria.name ILIKE E'%VTEC O157%') AND (viruses.name ILIKE E'%NOROVIRUS%')) LIMIT 1
Run Code Online (Sandbox Code Playgroud)

基本上我想将前两个语句的组合结果输出为与上述语句类似的格式(用"OR"条件代替"AND").但是,如果这不可能,我只需编写一个范围来处理SQL联合.

根据下面的回复来判断,我会选择两个单独的声明,欢呼:)

Dav*_*jak 5

我认为你是混淆OR与SQL联合运算符加入两个查询的返回.

OR用于管理语句的WHERE部分中的条件,而union用于将一个查询附加到另一个查询.

您应该注意,仅当两个查询具有相同的域时,联合才有效.从快速查看您的查询,它应该完全按照您的想法.

试试这个:

SELECT "outbreaks".* FROM "outbreaks" INNER JOIN "bacterial_agents" ON bacterial_agents.outbreak_id = outbreaks.id INNER JOIN "bacteria" ON "bacteria".id = "bacterial_agents".bacterium_id WHERE (bacteria.name ILIKE E'%VTEC O157%')
UNION
SELECT "outbreaks".* FROM "outbreaks" INNER JOIN "viral_agents" ON viral_agents.outbreak_id = outbreaks.id INNER JOIN "virus" ON "virus".id = "viral_agents".virus_id WHERE (virus.name ILIKE E'%NOROVIRUS%')
Run Code Online (Sandbox Code Playgroud)