gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-04 18:14:47 25 4
gpt4 key购买 nike

我有一个运行良好的 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com