Oracle
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Oracle

Giá trị khác nhau được tính trên cùng một cột

Bạn có thể sử dụng câu lệnh CASE hoặc DECODE bên trong hàm COUNT.

  SELECT item_category,
         COUNT (*) total,
         COUNT (DECODE (item_status, 'serviceable', 1)) AS serviceable,
         COUNT (DECODE (item_status, 'under_repair', 1)) AS under_repair,
         COUNT (DECODE (item_status, 'condemned', 1)) AS condemned
    FROM mytable
GROUP BY item_category;

Đầu ra:

ITEM_CATEGORY   TOTAL   SERVICEABLE UNDER_REPAIR    CONDEMNED
----------------------------------------------------------------
chair           5       1           2               2
table           5       3           1               1


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. ORA-01036:tên / số biến không hợp lệ khi chạy truy vấn thông qua C #

  2. Các chức năng phân tích LEAD và LAG

  3. Làm thế nào để có được quý từ ngày trong Oracle?

  4. Sử dụng Oracle EXPAND_SQL_TEXT

  5. xóa mili giây khỏi trường oracle tmstmp