结果中带有额外字段的 SQL UNION 查询

标签 sql select union field

我有一个运行良好的 SQL 查询,但我想将第一个数据库中另一列的结果带入它。这是我目前拥有的:

SELECT parts1.PART_NBR, parts1.NIIN
FROM parts1
WHERE parts1.PART_NBR='$pn'
UNION
SELECT parts2.REFERENCE_NUMBER, parts2.NIIN
FROM parts2
WHERE parts2.REFERENCE_NUMBER='$pn'

这就是我基本上想要的(当然这行不通):
SELECT parts1.PART_NBR, parts1.NIIN, parts1.ANOTHER_FIELD
FROM parts1
WHERE parts1.PART_NBR='$pn'
UNION
SELECT parts2.REFERENCE_NUMBER, parts2.NIIN
FROM parts2
WHERE parts2.REFERENCE_NUMBER='$pn'

我如何编写查询以使其执行相同的操作,但实际上会带回结果中的额外字段?

最佳答案

创建一个空字段,返回NULL

SELECT parts1.PART_NBR, parts1.NIIN, parts1.ANOTHER_FIELD
FROM parts1
WHERE parts1.PART_NBR='$pn'
UNION ALL
SELECT parts2.REFERENCE_NUMBER, parts2.NIIN, NULL AS ANOTHER_FIELD
FROM parts2
WHERE parts2.REFERENCE_NUMBER='$pn'

编辑:
从您的评论中,您看到的结果为
Part Number: 21223 NIIN: 008194914 Name: CAPACITOR
Part Number: 21223 NIIN: 011241926 Name: HEAT SINK
Part Number: 21223 NIIN: 003901600 Name: KNIFE
Part Number: 21223 NIIN: 003901600 Name: 
Part Number: 21223 NIIN: 008194914 Name:
Part Number: 21223 NIIN: 011241926 Name:

第一个结果来自表 parts1第二个来自 parts2 ,空白Name字段是您返回的位置 NULL .

根据您提供的信息,我不明白您为什么使用 UNION从这两个表中获取结果,因为它们似乎包含相同的信息,除了第一个表也有 Name field 。

不是更好JOIN零件/引用编号上的表格以选择名称?

编辑:
正如您在评论中所说,之前您收到了 DISTINCT结果集因为使用 UNION .与 NULL field 行不再唯一并且查询返回所有行。

我在评论中说,我看不到当前的 UNION 语句为您做什么,因为这两个表似乎都有相同的信息。这个查询比你告诉我们的更多吗?

关于结果中带有额外字段的 SQL UNION 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5846064/

相关文章:

mysql - 当您只有日期(没有时间部分)时按顺序求和列

MySQL COUNT 和 GROUP BY 子查询

sql - 从 SQL Server 下载图像

c++ - 在同一个 fd(socket) 上连续 2 次 SELECT 系统调用,一个需要时间,而第二个立即返回,为什么?

c# - 获取多选列表框的选中值

mysql - 在mysql中结合order by

php - 将最后一次 mysql 查询的信息保存到历史表中

PHP多关键字搜索功能

mysql - 如何获得与分组结果集连接的关系表的总和?

sql - SQL Union“所有其他”行