gpt4 book ai didi

c# - 将两个 SQL 查询合并为一个

转载 作者:行者123 更新时间:2023-11-30 22:13:26 25 4
gpt4 key购买 nike

我需要为 C# 中的特定方法执行原始 SQL(否则使用 NHibernate)并且我正在努力将查询合并到不同的表,因为除了 ORM 之外我几乎不使用其他表。在这种情况下,我正在查询其中的三个,并且我想在第二个查询的最后一行中使用第一个简单选择的结果中的 offerId(而不是使用硬编码的 1003)

SELECT * FROM [OFFER]
WHERE CampaignId = 1 AND Processed Is NULL

SELECT [BANK].* FROM [BANK]
INNER JOIN [REMINDER]
ON [BANK].personId = [REMINDER].personId AND [BANK].isCurrent = 1
WHERE [REMINDER].offerId = 1003

我曾尝试执行第一个查询,然后使用 foreach,但最终我会得到与结果一样多的数据库查询,所以它会降低性能,对吗?

谢谢

最佳答案

SELECT [BANK].* FROM [BANK]
INNER JOIN [REMINDER]
ON [BANK].personId = [REMINDER].personId AND [BANK].isCurrent = 1
WHERE [REMINDER].offerId in
(
SELECT offerId FROM [OFFER]
WHERE CampaignId = 1 AND Processed Is NULL
)

关于c# - 将两个 SQL 查询合并为一个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19161097/

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