当前位置:首页 » 编程语言 » sql正负数分组
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql正负数分组

发布时间: 2022-12-27 10:56:02

sql查询如何转换正负数

select 编号,-count(编号) as 列名 from 表 group by 编号

count里边的编号可以用星号来代替,不用写明是具体的哪个字段

以上,希望对你有所帮助!

Ⅱ 在SQL中如何把一列的正负数筛选出来各成一列

select n_name,
case when n_number>=0 then n_number else 0 end as n_numberAdd,
case when n_number<0 then n_number else 0 end as n_numberdec
from table

Ⅲ SQL对取值范围进行分组汇总的几种办法

可以用到自定义函数,
create or replace FUNCTION g2(v NUMBER) RETURN INT IS
TYPE it IS TABLE OF INT;
BEGIN
IF v>0 AND v<= 500 THEN
RETURN 1;
ELSIF v>500 AND v<= 1000 THEN
RETURN 2;
ELSIF v>1000 AND v<= 5000 THEN
RETURN 3;
ELSIF v>5000 AND v<= 20000 THEN
RETURN 4;
ELSE
RETURN 0;
END IF;
END g2;
/
select g2(id) f, count(1) cnt from t1 group by g2(id) order by 1;
F CNT
---------- ----------
1 500
2 500
3 4000
4 15000

当然,我们也可以不借助函数,而用case when语句实现同样的条件分组,但是语句比较冗长,列名是固定的。不利于阅读与修改,也不利于代码重用。
select (case
when id >0 AND id<= 500 THEN 1
when id >500 AND id<= 1000 THEN 2
when id >1000 AND id<= 5000 THEN 3
when id >5000 AND id<= 20000 THEN 4
else 0
end) f,
count(1) cnt from t1 group by
(case
when id >0 AND id<= 500 THEN 1
when id >500 AND id<= 1000 THEN 2
when id >1000 AND id<= 5000 THEN 3
when id >5000 AND id<= 20000 THEN 4
else 0
end)
order by 1;
F CNT
---------- ----------
1 500
2 500
3 4000
4 15000

Ⅳ SQL 分组数据

连载的上一篇文章,我们讲到通过 SQL 聚合函数可以汇总数据,比如对行进行计数,计算和与平均数,获取最大值和最小值。

但目前为止,我们的汇总都是正对所有行或匹配 WHERE 子句的数据上进行的。比如返回供应商 DLL01 提供的产品数目:

运行结果:

那如果我们想要返回每个供应商提供的产品数目呢?这就需要用到分组聚合了。使用分组可以将数据分为多个逻辑组,然后对每个组进行聚合计算。

分组的创建使用 SELECT 语句中的 GROUP BY 子句,比如下面的 SQL 返回每个供应商提供的产品数目:

运行结果:

上述 SELECT 语句返回两个列, vend_id 为供应商 ID,是分组字段; num_prods 为计算字段,使用 count(*) 聚合而来。 GROUP BY 子句告诉 DBMS 按 vend_id 排序并分组数据,然后对每个分组而不是整个数据集进行聚合。

除了使用 GROUP BY 分组数据外, SQL 还允许过滤分组,规定包含哪些分组,排除哪些分组。比如,我们只想列出供应产品数目在 2 种以上的供应商及其供应产品的数目。

这里有个过滤条件: 供应产品数目大于 2 ,条件中的 供应产品数目 是针对分组后进行聚合产生的计算字段,因此无法使用 WHERE 子句。 WHERE 子句过滤时指定的是行,而不是分组。

为此, SQL 提供了 HAVING 子句来过滤分组,并且 HAVING 支持所有 WHERE 操作符。下面,我们来完成供应产品数目在 2 种以上的供应商及其供应产品的数目。

运行结果:

跟前面的结果相比,供应产品数目等于 2 的供应商信息就不见啦~

关于 WHERE 子句和 HAVING 子句的区别,我们可以再通过一个案例理解一下。下面的 SQL 检索具有两个或以上产品且其价格大于等于 4 的供应商。

其中产品表如下:

SQL 语句如下:

运行结果:

截止目前,我们已经学了不少的 SELECT 子句,下面小鱼针对目前我们已经学习的 SELECT 子句来总结一下他们在 SELECT 语句中的先后顺序。

表中子句的排列顺序即为它们在 SELECT 语句中依次出现的次序:

还是上面的例子,检索具有两个或以上产品且其价格大于等于 4 的供应商和其供应的产品数目,不过检索检索需要按照产品数目升序排列。

运行结果:

本节,我们学习了使用 GROUP BY 子句对多组数据进行汇总计算,并返回每个分组的结果。并实践了如何使用 HAVING 子句过滤分组。

Ⅳ sql语句实现分组统计

方法和详细的操作步骤如下:

1、第一步,创建一个测试表,详细代码见下图,转到下面的步骤。

Ⅵ SQL显示正负数问题,请求SQL高手帮助

可以写 case when 商品编号 like 'XSCKTH%' then 销售金额*-1 else 销售金额 end

Ⅶ SQL数据分组汇总

你没说什么数据库,,,

提供sqlserver的方法


SELECTLEFT(c,CHARINDEX('-',c)-1),sum(d)
from表
groupbyLEFT(c,CHARINDEX('-',c)-1)

Ⅷ SQL对查询结果进行分组

如果你的UID是int型先进行转换,然后截取前两位,在用聚合函数获取总数,进行分组查询就好了,语句如下(把表名替换下可以直接用):select SUBSTRING(CONVERT(varchar(50),UID),0,3),COUNT(*) from 表 group by SUBSTRING(CONVERT(varchar(50),UID),0,3)

Ⅸ SQL数据分组统计问题

SELECT规格,批号,色别,等级,
SUM(毛重)AS毛重,SUM(净重)AS净重,SUM(筒子)AS筒子,SUM(箱数)AS箱数
FROMTGROUPBY规格,批号,色别,等级

这里你提供的数据,等级字段值都是A,所以不会造成错误,不然等级也是要加入分组的。