我需要为 C# 中的特定方法(否则使用 NHibernate)执行原始 SQL,并且我正在努力将查询合并到不同的表,因为除了 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,但最终我会对数据库进行与结果一样多的查询,因此它会降低性能,对吗?
谢谢