oracle 用SUM 和CASE WHEN函数根据一个字段的一些条件统计数量并按另一个字段去重 语句怎么写
时间: 2024-03-12 21:45:28 浏览: 238
您可以使用以下 Oracle SQL 语句来使用 `SUM` 和 `CASE WHEN` 函数根据一个字段的一些条件统计数量并按另一个字段去重:
```
SELECT
COUNT(DISTINCT another_field),
SUM(CASE WHEN your_field = your_condition_1 THEN 1 ELSE 0 END) AS count_1,
SUM(CASE WHEN your_field = your_condition_2 THEN 1 ELSE 0 END) AS count_2,
SUM(CASE WHEN your_field = your_condition_3 THEN 1 ELSE 0 END) AS count_3
FROM your_table;
```
其中,`another_field` 为您想要去重的字段,`your_table` 为您的表名,`your_field` 为您想要筛选的字段名,`your_condition_x` 为您想要筛选的条件。请根据实际情况替换这些参数。
这条 SQL 语句将会返回去重后的 `another_field` 字段数量,以及根据 `your_field` 字段的三个条件分别统计的数量结果。您可以根据实际情况修改 `CASE WHEN` 中的条件,并添加更多的 `SUM` 和 `CASE WHEN` 子句。
相关问题
oracle用case when计数,SUM统计使用CASE WHEN
当需要在Oracle数据库中进行统计时,可以使用CASE WHEN语句对数据进行条件分组,并使用SUM函数对分组后的数据进行求和。
例如,假设有一个orders表,其中包含订单信息和订单状态。要计算每个状态的订单数和总金额,可以使用以下查询:
```
SELECT
status,
COUNT(CASE WHEN status = 'completed' THEN 1 ELSE NULL END) as num_completed_orders,
COUNT(CASE WHEN status = 'cancelled' THEN 1 ELSE NULL END) as num_cancelled_orders,
SUM(CASE WHEN status = 'completed' THEN amount ELSE 0 END) as total_completed_amount,
SUM(CASE WHEN status = 'cancelled' THEN amount ELSE 0 END) as total_cancelled_amount
FROM orders
GROUP BY status;
```
在这个查询中,我们使用了CASE WHEN语句将数据按照订单状态进行分组,然后使用COUNT和SUM函数对每个分组内的数据进行统计。注意,在COUNT函数中,我们使用了NULL代替0,这是为了避免对不存在的订单状态进行计数。
使用类似的方法,可以对其他字段进行分组和统计。
oracle case when 字段比较
在Oracle中,可以使用CASE WHEN语句来比较字段的值。在使用CASE WHEN语句时,可以根据需要进行等值判断或表达式判断。与DECODE函数相比,CASE WHEN更灵活,可以用于=,>=,<,<=,<>,IS NULL,IS NOT NULL,BETWEEN等多种判断条件。以下是一些示例:
1. 使用CASE WHEN进行等值判断:
```sql
SELECT CASE WHEN 字段名 = '1' THEN '条件1'
WHEN 字段名 = '2' THEN '条件2'
ELSE '其他条件'
END AS 别名
FROM 表名;
```
2. 使用CASE WHEN进行表达式判断:
```sql
SELECT CASE WHEN INSTR(hiredate, '82') = 0 THEN 0
ELSE 1
END AS "year"
FROM emp;
```
3. 使用CASE WHEN进行多条件判断和求和:
```sql
SELECT COUNT(*) AS total,
SUM(CASE WHEN INSTR(hiredate, '80') = 0 THEN 0
ELSE 1
END) AS "1980",
SUM(CASE WHEN INSTR(hiredate, '81') = 0 THEN 0
ELSE 1
END) AS "1981",
SUM(CASE WHEN INSTR(hiredate, '82') = 0 THEN 0
ELSE 1
END) AS "1982",
SUM(CASE WHEN INSTR(hiredate, '87') = 0 THEN 0
ELSE 1
END) AS "1987"
FROM emp;
```
以上是使用CASE WHEN对字段进行比较的示例。可以根据实际需求灵活运用CASE WHEN来满足不同的条件判断和逻辑运算。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [Oracle case when对字段的空值判断及其两种用法](https://blog.csdn.net/weixin_40364882/article/details/118394307)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *3* [oracle 学习笔记 - DECODE函数和CASE WHEN 比较](https://blog.csdn.net/u010758410/article/details/77285290)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文