เลือกจำนวน (*) จากหลายตาราง


229

ฉันจะเลือกcount(*)จากสองตารางที่แตกต่างกัน (เรียกพวกเขาtab1และtab2) มีผลดังนี้:

Count_1   Count_2
123       456

ฉันเคยลองแล้ว:

select count(*) Count_1 from schema.tab1 union all select count(*) Count_2 from schema.tab2

แต่สิ่งที่ฉันมีคือ:

Count_1
123
456

คำตอบ:


327
SELECT  (
        SELECT COUNT(*)
        FROM   tab1
        ) AS count1,
        (
        SELECT COUNT(*)
        FROM   tab2
        ) AS count2
FROM    dual

14
ทำไมคุณถึงต้องการคู่? นั่นหมายความว่าอย่างไร?
Ray Lu

31
เป็นตารางปลอมที่มีหนึ่งระเบียน คุณไม่สามารถเลือกได้หากไม่มี FROM ใน Oracle
Quassnoi

3
dual เป็นตารางในฐานข้อมูล oracle ที่บัญชีทั้งหมดสามารถเข้าถึงคุณสามารถใช้สำหรับความต้องการทั่วไปเช่น "SELECT sysdate FROM dual"
dincerm

5
มันไม่สร้างความแตกต่างเลย Oracle จะไม่ประเมินสิ่งใดภายใน COUNT (*)
Quassnoi

4
@ Stéphane: สิ่งนี้เกิดขึ้นเมื่อคุณลองใช้รหัส Oracle บน PostgreSQL FROM dualสูญเสีย
Quassnoi

81

ในฐานะที่เป็นข้อมูลเพิ่มเติมเพื่อให้บรรลุสิ่งเดียวกันใน SQL Server คุณเพียงแค่ลบส่วน "FROM คู่" ของแบบสอบถาม


1
ฉันเพิ่งพร้อมที่จะพูดว่า "แต่สิ่งที่เกี่ยวกับ MS SQL เมื่อฉันเห็นความคิดเห็นของคุณขอบคุณสำหรับการคาดการณ์ความต้องการ!
Andrew Neely

40

เพียงเพราะมันแตกต่างกันเล็กน้อย:

SELECT 'table_1' AS table_name, COUNT(*) FROM table_1
UNION
SELECT 'table_2' AS table_name, COUNT(*) FROM table_2
UNION
SELECT 'table_3' AS table_name, COUNT(*) FROM table_3

มันให้คำตอบ transposed (หนึ่งแถวต่อตารางแทนที่จะเป็นหนึ่งคอลัมน์) มิฉะนั้นฉันไม่คิดว่ามันจะแตกต่างกันมาก ฉันคิดว่าพวกเขาควรจะมีประสิทธิภาพเทียบเท่ากัน


1
คุณควรใส่ UNION ALL ที่นี่
Quassnoi

ความแตกต่างอะไรที่สามารถเพิ่มคำว่า "ALL" ด้วยคำค้นหาแถวเดี่ยวสามแถว ผลลัพธ์จะต้องเหมือนกันด้วยวิธีใด?
Mike Woodhouse

1
UNION ที่ไม่มีผลลัพธ์กลุ่มทั้งหมด หากมี 2 แถวใน table_1 และ table_2 และ 3 แถวใน table_3 คุณจะได้รับสองแถวในเซตผลลัพธ์ของคุณและจะไม่สามารถบอกจาก resultset ได้ว่า table_2 มีกี่แถว: 2 หรือ 3
Quassnoi

4
ใช่ แต่ฉันเลือกชื่อตารางซึ่งทำให้ผลลัพธ์ไม่ซ้ำกัน มิฉะนั้นคุณจะถูกต้อง แต่สิ่งที่จะมีค่าในตัวเลขจำนวนมากโดยไม่มีบริบท? ;-)
Mike Woodhouse

นี่เป็นวิธีที่ดีในการใช้คำสั่ง CTE (WITH SELECT) สำหรับการนับแต่ละครั้ง
blue_chip

28

ประสบการณ์ของฉันอยู่กับ SQL Server แต่คุณสามารถทำได้:

select (select count(*) from table1) as count1,
  (select count(*) from table2) as count2

ใน SQL Server ฉันได้ผลลัพธ์ตามที่คุณต้องการ


11

วิธีการที่แตกต่างกันเล็กน้อยอื่น ๆ :

with t1_count as (select count(*) c1 from t1),
     t2_count as (select count(*) c2 from t2)
select c1,
       c2
from   t1_count,
       t2_count
/

select c1,
       c2
from   (select count(*) c1 from t1) t1_count,
       (select count(*) c2 from t2) t2_count
/

7

ในขณะที่ฉันไม่เห็นคำตอบอื่นใดนำมาซึ่งสิ่งนี้

หากคุณไม่ชอบข้อความค้นหาย่อยและมีคีย์หลักในแต่ละตารางคุณสามารถทำได้:

select count(distinct tab1.id) as count_t1,
       count(distinct tab2.id) as count_t2
    from tab1, tab2

แต่ประสิทธิภาพที่ชาญฉลาดฉันเชื่อว่าทางออกของ Quassnoi นั้นดีกว่าและฉันก็ควรใช้



7

นี่คือจากฉันที่จะแบ่งปัน

ตัวเลือก 1 - การนับจากโดเมนเดียวกันจากตารางที่แตกต่างกัน

select distinct(select count(*) from domain1.table1) "count1", (select count(*) from domain1.table2) "count2" 
from domain1.table1, domain1.table2;

ตัวเลือก 2 - การนับจากโดเมนที่แตกต่างกันสำหรับตารางเดียวกัน

select distinct(select count(*) from domain1.table1) "count1", (select count(*) from domain2.table1) "count2" 
from domain1.table1, domain2.table1;

ตัวเลือก 3 - การนับจากโดเมนที่แตกต่างกันสำหรับตารางเดียวกันโดยมี "union all" เพื่อให้มีจำนวนแถว

select 'domain 1'"domain", count(*) 
from domain1.table1 
union all 
select 'domain 2', count(*) 
from domain2.table1;

สนุกกับ SQL ฉันทำได้เสมอ :)




6

แทงอย่างรวดเร็วเกิดขึ้นกับ:

Select (select count(*) from Table1) as Count1, (select count(*) from Table2) as Count2

หมายเหตุ: ฉันทดสอบสิ่งนี้ใน SQL Server ดังนั้นจึงFrom Dualไม่จำเป็น (ดังนั้นความแตกต่าง)


5

เพื่อความสมบูรณ์แบบเล็กน้อยแบบสอบถามนี้จะสร้างแบบสอบถามเพื่อให้คุณนับจำนวนทั้งหมดของตารางสำหรับเจ้าของที่ระบุ

select 
  DECODE(rownum, 1, '', ' UNION ALL ') || 
  'SELECT ''' || table_name || ''' AS TABLE_NAME, COUNT(*) ' ||
  ' FROM ' || table_name  as query_string 
 from all_tables 
where owner = :owner;

ผลลัพธ์เป็นสิ่งที่ชอบ

SELECT 'TAB1' AS TABLE_NAME, COUNT(*) FROM TAB1
 UNION ALL SELECT 'TAB2' AS TABLE_NAME, COUNT(*) FROM TAB2
 UNION ALL SELECT 'TAB3' AS TABLE_NAME, COUNT(*) FROM TAB3
 UNION ALL SELECT 'TAB4' AS TABLE_NAME, COUNT(*) FROM TAB4

ซึ่งคุณสามารถเรียกใช้เพื่อรับจำนวนของคุณ บางครั้งมันก็เป็นสคริปต์ที่มีประโยชน์


4

หากตาราง (หรืออย่างน้อยคอลัมน์สำคัญ) เป็นประเภทเดียวกันให้ทำการรวมกันก่อนแล้วจึงนับ

select count(*) 
  from (select tab1key as key from schema.tab1 
        union all 
        select tab2key as key from schema.tab2
       )

หรือเอาป้อยอของคุณและใส่อีก () รอบ ๆ

select sum(amount) from
(
select count(*) amount from schema.tab1 union all select count(*) amount from schema.tab2
)

3
--============= FIRST WAY (Shows as Multiple Row) ===============
SELECT 'tblProducts' [TableName], COUNT(P.Id) [RowCount] FROM tblProducts P
UNION ALL
SELECT 'tblProductSales' [TableName], COUNT(S.Id) [RowCount] FROM tblProductSales S


--============== SECOND WAY (Shows in a Single Row) =============
SELECT  
(SELECT COUNT(Id) FROM   tblProducts) AS ProductCount,
(SELECT COUNT(Id) FROM   tblProductSales) AS SalesCount


0

เข้าร่วมกับตารางที่แตกต่างกัน

SELECT COUNT(*) FROM (  
SELECT DISTINCT table_a.ID  FROM table_a JOIN table_c ON table_a.ID  = table_c.ID   );


-2
select @count = sum(data) from
(
select count(*)  as data from #tempregion
union 
select count(*)  as data from #tempmetro
union
select count(*)  as data from #tempcity
union
select count(*)  as data from #tempzips
) a

ยินดีต้อนรับสู่ StackOverflow และขอบคุณสำหรับการโพสต์ โปรดดูที่วิธีการตอบ
Serge Belov

คำตอบนี้ผิด ไม่สามารถใช้สหภาพ (ควรใช้สหภาพทั้งหมด)
Deadsheep39
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.