2

我有以下表格:

filetype1
F1_ID | F1_ORDR | FILENAME
1     | 1        | file1.txt
2     | 2        | file2.txt
3     | 3        | file3.txt
4     | 2        | file4.txt
5     | 4        | file5.txt

filetype2
F2_ID | F2_ORDR | FILENAME
1     | 1        | file6.txt
2     | 2        | file7.txt
3     | 4        | file8.txt

ordr
OR_ID | OR_VENDOR
1     | 1
2     | 1
3     | 1
4     | 1

vendor
VE_ID | VE_NAME
1     | Company1

我的目标是有一个供应商列表和每个类型的文件连接的订单数量。例如,此数据的最终结果应该是:

VENDOR   | OR_CT | F1_CT | F2_CT
Company1 | 4        | 4        | 3

因为至少 1 个 type1 文件附加到 4 个不同的订单,至少 1 个 type2 文件附加到 3 个不同的订单。目前我的 SQL 代码如下所示:

SELECT vendor.ve_id, vendor.ve_name,
       (SELECT COUNT(or_id)
        FROM ordr
        WHERE ordr.or_vendor = vendor.ve_id) as OR_COUNT, 
       (SELECT COUNT(DISTINCT f1_order)
        FROM filetype1 INNER JOIN ordr ON filetype1.f1_ordr = ordr.or_id
        WHERE ordr.or_vendor = vendor.ve_id) as F1_CT,
       (SELECT COUNT(DISTINCT f2_ordr)
        FROM filetype2 INNER JOIN ordr ON filetype2.f2_ordr = ordr.or_id
        WHERE ordr.or_vendor = vendor.ve_id) as F2_CT
FROM vendor
ORDER BY vendor.ve_name

不幸的是,这会产生以下结果:

VENDOR   | OR_COUNT | F1_COUNT | F2_COUNT
Company1 | 4        | 5        | 3

我唯一的猜测是,因为我正在使用COUNT(DISTINCT)isCOUNT自动假设DISTINCT是 order byF1_ID而不是 byF1_ORDR

如果有人可以帮助我如何告诉COUNT(DISTINCT)订购,F1_ORDR那将是最有帮助的。我在广阔的互联网上搜索了一个解决方案,但很难向搜索引擎、论坛等解释我想要什么。我的数据库使用 Microsoft SQL Server。我的数据库管理知识几乎完全是自学的,所以我很高兴自己能做到这一点。我的专长是网页设计。感谢您的时间。

4

3 回答 3

1

您的 SQL 会产生您想要的结果。

两条忠告

  1. 订单是表的坏名称 - 它与保留字冲突,并且会给您带来无穷无尽的麻烦

  2. 你应该像这样加入你的桌子

    FROM filetype1 inner join [order] on filetype1.f1_order = or_id

而不是使用 where 子句

也许试试这个

select 
    vendor.VE_ID, vendor.VE_NAME,   
    count(distinct or_id),
    count(distinct f1_order),
    count(distinct f2_order)

from 
    vendor
        left join [order]
            on vendor.VE_ID = [order].OR_VENDOR
        inner join filetype1 
            on [order].OR_ID = filetype1.F1_ORDER
        left join filetype2
            on [order].OR_ID = filetype2.F2_ORDER
group by
    vendor.VE_ID, vendor.VE_NAME
于 2012-08-21T20:14:32.927 回答
0

我会建议你:

将 filetype1 和 filetype2 表合并到一个表(文件类型)中,并添加另一个名为 - f_type(例如)类型为 INT 或 TINTYINT 的字段来存储文件类型(1 或 2)。这具有稍后轻松添加另一个文件类型的好处现在查询将如下所示:

SELECT 
vendor.ve_name,
count(DISTINCT filetype.f_order),
filetype.f_type
FROM 
   filetype
       INNER JOIN `order`
           ON filetype.f_order = `order`.or_id
       INNER JOIN vendor
           ON `order`.or_vendor = vendor.ve_id
   GROUP BY vendor.ve_id,filetype.f_type

这将给出文件类型的订单计数。

对于总订单,只需添加另一个查询:

SELECT count(*) FROM `order`
于 2012-08-21T21:19:31.837 回答
0

尝试这个:

SELECT
vdr.VE_NAME   
,COUNT(DISTINCT OR_ID) AS OR_ID 
,COUNT(DISTINCT ft1.F1_ORDER) AS FT1_COUNT
,COUNT(DISTINCT ft2.F2_ORDER) AS FT2_COUNT
FROM
    vendor vdr
    LEFT OUTER JOIN [order] odr
        ON vdr.VE_ID = odr.OR_VENDOR
    INNER JOIN filetype1 ft1
        ON  odr.OR_ID = ft1.F1_ORDER
    LEFT OUTER JOIN filetype2 ft2
        ON odr.OR_ID = ft2.F2_ORDER
GROUP BY
    vdr.VE_ID
    ,vdr.VE_NAME
于 2012-08-21T20:49:20.230 回答