在单个查询中汇总具有总和百分比的表

Summarize tables with percent of sum in single query

我有一个 ACTIVE_TRANSPORTATION table:

+--------+----------+--------+
| ATN_ID |   TYPE   | LENGTH |
+--------+----------+--------+
|      1 | SIDEWALK |   20.6 |
|      2 | SIDEWALK |   30.1 |
|      3 | TRAIL    |   15.9 |
|      4 | TRAIL    |   40.4 |
|      5 | SIDEWALK |   35.2 |
|      6 | TRAIL    |   50.5 |
+--------+----------+--------+

它通过 ATN_IDINSPECTION table 相关:

+---------+--------+------------------+
| INSP_ID | ATN_ID | LENGTH_INSPECTED |
+---------+--------+------------------+
|     101 |      2 |             15.2 |
|     102 |      3 |              5.4 |
|     103 |      5 |             15.9 |
|     104 |      6 |             20.1 |
+---------+--------+------------------+

我想把信息总结成这样:

+----------+--------+-------------------+
|   TYPE   | LENGTH | PERCENT_INSPECTED |
+----------+--------+-------------------+
| SIDEWALK |   85.9 |               36% |
| TRAIL    |  106.8 |               23% |
+----------+--------+-------------------+

如何在 单个 查询中执行此操作?

这里是使用ACCESS 2010更新的答案。注意ACCESS中保留了LENGTH,所以需要改成LENGTH_

SELECT 
       TYPE,
       SUM(LENGTH) as LENGTH_,
       SUM(IIF(ISNULL(LENGTH_INSPECTED),0, LENGTH_INSPECTED))/SUM(LENGTH) as  PERCENT_INSPECTED
FROM 
ACTIVE_TRANSPORTATION A
LEFT JOIN INSPECTION B 
    ON A.ATN_ID = B.ATN_ID
GROUP BY TYPE

这是我最初在 SQL SERVER 2014 中使用 T-SQL 的答案

SELECT SUM(LENGTH) as LENGTH,
       SUM(ISNULL(LENGTH_INSPECTED,0))/SUM(LENGTH) as PERCENT_INSPECTED,
       TYPE
FROM 
ACTIVE_TRANSPORTATION A
LEFT JOIN INSPECTION B 
    ON A.ATN_ID = B.ATN_ID
GROUP BY TYPE

如果您需要将其转换为百分比、四舍五入等,请告诉我,但我猜这部分对您来说很容易。