2

次の SQL スクリプトがあります。

  SELECT       
    vapp.NAME
  , memcpu.[MEM_SIZE_MB]/1000
  , memcpu.[NUM_VCPU]
  , sum(convert(bigint, hdd.CAPACITY))
  FROM [VCenterServer].[dbo].[VPX_VM] AS memcpu
  INNER JOIN [VCenterServer].[dbo].[VPX_GUEST_DISK] AS hdd
  ON memcpu.ID = hdd.VM_ID
  INNER JOIN [VCenterServer].[dbo].[VPXV_RESOURCE_POOL] AS vapp
  ON memcpu.RESOURCE_GROUP_ID = vapp.RESOURCEPOOLID
  GROUP BY 
  memcpu.[ID]
  , memcpu.[DNS_NAME] 
  , memcpu.[MEM_SIZE_MB]
  , memcpu.[NUM_VCPU]
  , hdd.PATH
  , hdd.CAPACITY
  , vapp.RESOURCEPOOLID
  , vapp.NAME;

この結果をもたらします

NAME      MEM     NUM_VCPU  CAPACITY
Core       3            1   42947571712
Core       2            1   42947571712
Core       4            1   42947571712
Core       4            1   134214578176
Phones     2            2   26977628160
Phones     2            2   103442432
Phones     1            1   37378260992
Phones     1            1   103442432

私がやりたいことは、名前に基づいて MEM NUM_VCPU と CAPACITY を合計するだけでなく、名前も保持することです。

NAME      MEM     NUM_VCPU  CAPACITY
Core      13         4      263057293312
Phones    6          6      64562774016

アップデート:

回答に基づいて SQL コードを調整したところ、次のように動作します。

select t1.NAME, t1.STORAGE, t2.CPU, t2.MEMORY
from 
(SELECT vapp.NAME [NAME]
     ,SUM(ceiling(convert(decimal(21, 0), hdd.CAPACITY)/(1024*1024*1024))) AS STORAGE
     FROM [VCenterServer].[dbo].[VPX_VM] AS memcpu
     INNER JOIN [VCenterServer].[dbo].[VPX_GUEST_DISK] AS hdd
     ON memcpu.ID = hdd.VM_ID
     INNER JOIN [VCenterServer].[dbo].[VPXV_RESOURCE_POOL] AS vapp
     ON memcpu.RESOURCE_GROUP_ID = vapp.RESOURCEPOOLID
     GROUP BY vapp.NAME  
) t1
left join
(SELECT vapp.NAME [NAME]
     ,SUM(memcpu.[MEM_SIZE_MB]/1024) AS [MEMORY]
     ,SUM(memcpu.[NUM_VCPU]) AS [CPU]
     FROM [VCenterServer].[dbo].[VPX_VM] AS memcpu
     INNER JOIN [VCenterServer].[dbo].[VPXV_RESOURCE_POOL] AS vapp
     ON memcpu.RESOURCE_GROUP_ID = vapp.RESOURCEPOOLID
     GROUP BY vapp.NAME  
) t2
on
t1.NAME = t2.NAME
ORDER BY t1.NAME
4

2 に答える 2

1

GROUP BY 句から不要な列を単純に削除できます

  SELECT vapp.NAME
         ,SUM(memcpu.[MEM_SIZE_MB]/1000) AS [MEM_SIZE_MB]
         ,SUM(memcpu.[NUM_VCPU]) AS [NUM_VCPU]
         ,SUM(convert(bigint, hdd.CAPACITY)) AS CAPACITY
  FROM [VCenterServer].[dbo].[VPX_VM] AS memcpu
    INNER JOIN [VCenterServer].[dbo].[VPX_GUEST_DISK] AS hdd
      ON memcpu.ID = hdd.VM_ID
    INNER JOIN [VCenterServer].[dbo].[VPXV_RESOURCE_POOL] AS vapp
      ON memcpu.RESOURCE_GROUP_ID = vapp.RESOURCEPOOLID
  GROUP BY vapp.NAME;
于 2013-09-21T21:27:40.240 に答える