2017-08-29 91 views
2

我有以下三个表:是否可以在select语句中包含子查询?

dbo_CURRENCYRATES 
+-------------+---------+---------------+ 
|CURRENCY_ID |BUY_RATE |DATE_EFFECTIVE | 
+-------------+---------+---------------+ 
|GBP   |1.5  |01/01/2000  | 
|USD   |2.5  |01/01/2000  | 
|EUR   |0.5  |01/01/2000  | 
|GBP   |1.7  |01/01/2017  | 
|USD   |2.7  |01/01/2017  | 
|EUR   |0.7  |01/01/2017  | 
+-------------+---------+---------------+ 

dbo_DISCOUNTRATES 
+-------------+--------------+ 
|DISCOUNT  |DISCOUNT_RATE | 
+-------------+--------------+ 
|50   |0.5   | 
|25   |0.25   | 
|35   |0.35   | 
+-------------+--------------+ 

dbo_CUSTOMER 
+-------+---------------+---------+----------+ 
|ID  |NAME   |CURRENCY | DISCOUNT | 
+-------+---------------+---------+----------+ 
|1  |Widgets INC |USD  |50  | 
|2  |Widgets GMBH |EUR  |35  | 
|3  |Widgets PLC |GBP  |25  | 
+-------+---------------+---------+----------+ 

和查询

CurrentExchangeRate 
+--------------------------------------------+ 
SELECT 
    a.CURRENCY_ID 
    ,a.BUY_RATE 
FROM dbo_CURRENCYRATES AS t 
    INNER JOIN 
     (
     SELECT 
      CURRENCY_ID 
     ,MAX(DATE_EFFECTIVE) AS MaxDate 
     FROM dbo_CURRENCYRATES 
     GROUP BY dbo_CURRENCYRATES.CURRENCY_ID 
    ) AS tm 
      ON (a.CURRENCY_ID = b.CURRENCY_ID) 
      AND (a.DATE_EFFECTIVE = b.MaxDate); 

我具有从dbo_CUSTOMER选择数据的选择查询,其包括货币和折扣。

SELECT 
    dbo_CUSTOMER.ID 
    ,dbo_CUSTOMER.NAME 
    ,dbo_CUSTOMER.CURRENCY_ID AS [CURRENCY] 
    ,BUY_RATE 
    ,dbo_CUSTOMER.DISCOUNT 
    ,DISCOUNT_RATE 
FROM dbo_CUSTOMER 
WHERE ID = '1'; 

是可以在此查询,子查询,它可以让我得到了货币BUY_RATE(从一个单独的查询),并通过查询另一个表的恰当的折现率包括哪些内容?

我有一个单独的查询来获得货币汇率,因为我需要具有特定货币的最新值。

所以,在伪代码,我可以做到这一点:

SELECT 
    dbo_CUSTOMER.ID 
    ,dbo_CUSTOMER.NAME 
    ,dbo_CUSTOMER.CURRENCY_ID AS [CURRENCY] 
    ,dbo_CUSTOMER.DISCOUNT 
    ,(
    SELECT BUY_RATE 
    FROM CurrentExchangeRate 
    WHERE CurrentExchangeRate.CURRENCY_ID = [CURRENCY] 
    ) as BUY_RATE 
    ,(
    SELECT DISCOUNT_RATE 
    FROM dbo_DISCOUNTRATES 
    WHERE dbo_DISCOUNTRATES.DISCOUNT = dbo_CUSTOMER.DISCOUNT 
    ) as DISCOUNT_RATE 
FROM dbo_CUSTOMER 
WHERE ID = '1'; 

是可以做到这一点,首先在查询其次在访问数据库?

谢谢

+0

是的,你可以(在一个查询 - 我期望在访问数据库以及)。 – AlexT82

+0

在示例中,您显示子查询必须返回单个记录 - 所有记录的值相同。这通常是使用聚合查询或TOP 1完成的。由于在子查询中有动态条件,我希望您确实需要将查询连接到表。查看http://allenbrowne.com/subquery-01.html#TopN – June7

回答

1

是的,你可以。只有提示,您需要知道您的子查询中,您需要的是,您需要在日期字段中选择TOP 1和ORDER BY DESC。

相关问题