问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Oracle如何对一个多值字段进行分组统计

发布网友 发布时间:2022-04-23 18:40

我来回答

6个回答

懂视网 时间:2022-05-01 09:42

常用组函数:
1.ccount() 求出全部记录数。
2.max() 求出一组最大值
3.min() 求出一组最小值
4.avg() 求出平均值
5.sum() 求和


--1.统计员工数量:
select count(empno) from emp;

--2.求出最高薪资
select max(sal) from emp;

--3.求出最低薪资
select min(sal) from emp;

--4.求出平均薪资
select avg(sal) from emp;

--查询各部门员工数量
select deptno,count(empno) from emp group by deptno

--查询各部门平均工资
select deptno,avg(sal) from emp group by deptno
--注意:分组函数只能单独使用,或者指定分组条件,这样可以将分组条件查询出来。
select empno,count(sal) from emp;---无法执行

select deptno,avg(sal) from emp where avg(sal) >2000 group by deptno--无法执行
----注意:分组函数不能作为条件在hwere中使用,只能在having中使用。
select deptno,avg(sal) from emp group by deptno having avg(sal) >2000

select max(avg(sal)) from emp group by deptno;--嵌套的分组函数只能单独使用

--查询非销售人员的工作名称,以及从事同一个工作的人员薪资总和,并且要满足从事同一个工作的工作总和大于5000,安排工资合计升序。
select job ,sum(sal) su from emp where job <> ‘SALESMAN‘ group by job having sum(sal) >5000 order by su;

oracle学习篇五:组函数,分组统计

标签:

热心网友 时间:2022-05-01 06:50


CREATE  TABLE  info (
    users    varchar(100)
);

INSERT INTO info VALUES('userA@userB@userC');
INSERT INTO info VALUES('userB@userC@userD');
INSERT INTO info VALUES('userC@userD@userE');



COLUMN "用户" FORMAT A15


SELECT
  to_char(strvalue) as "用户",
  count(*) AS "用户数"
FROM
  info,
  table(fn_split( info.users,  '@'))
GROUP BY
  to_char(strvalue)
ORDER BY
  1;


用户                用户数
--------------- ----------
userA                    1
userB                    2
userC                    3
userD                    2
userE                    1





上面这样的效果, 是否满足你的需求?

如果满足的话, 你再往下看, 下面是 存储过程的相关代码

Oracle 需要首先在数据库中, 创建好 类型 与 函数。
来实现一个  split 功能的处理。



-- 定义一个对象类型.
CREATE OR REPLACE TYPE ty_row_str_split as object (strValue VARCHAR2 (4000));
/

-- 定义一个 表/数组类型, 内容是前面定义的那个对象.
CREATE OR REPLACE TYPE ty_tbl_str_split IS TABLE OF ty_row_str_split;
/

--------------------
-- 字符分割函数.
-- 参数1:  被分割的源字符串
-- 参数2:  用于拆分的字符串。
--------------------
CREATE OR REPLACE FUNCTION fn_split(
  p_str       IN VARCHAR2,
  p_delimiter IN VARCHAR2)
RETURN ty_tbl_str_split IS
  j         INT := 0;
  i         INT := 1;
  -- 被分割的源字符串 的长度.
  len       INT := 0;
  -- 分隔字符串的长度
  len1      INT := 0;
  -- 暂存的中间每一个单元的文本信息.
  str       VARCHAR2(4000);
  -- 预期返回结果.
  str_split ty_tbl_str_split := ty_tbl_str_split();
BEGIN
  -- 被分割的源字符串 的长度.
  len   := LENGTH(p_str);
  -- 分隔字符串的长度.
  len1 := LENGTH(p_delimiter);

  -- 遍历 被分割的源字符串.
  WHILE j < len LOOP
    -- 在被分割的源字符串中, 查询 分隔字符串.
    j := INSTR(p_str, p_delimiter, i);

    IF j = 0 THEN
      -- j=0 意味着没有找到.
  -- 可以理解为是查询到最后一个单元了.
  -- 设置 j := len, 让外部的循环处理可以结束了.
      j  := len;
      -- 获取最后一个单元的内容.
      str := SUBSTR(p_str, i);
      -- 结果追加一行.
      str_split.EXTEND;
      -- 设置结果内容.
      str_split(str_split.COUNT) := ty_row_str_split(strValue => str);

      IF i >= len THEN
        EXIT;
      END IF;
    ELSE
      -- 如果在被分割的源字符串中,找到了 分隔字符串.
      -- 首先,获取分割的内容.
      str := SUBSTR(p_str, i, j - i);
      -- 然后设置索引, 下一次再查找的时候,从指定的索引位置开始(不是从0开始找了)
      i := j + len1;
      -- 结果追加一行.
      str_split.EXTEND;
      -- 设置结果内容.
      str_split(str_split.COUNT) := ty_row_str_split(strValue => str);
    END IF;
  END LOOP;


  RETURN str_split;
END fn_split;
/




函数创建完毕以后,可以开始做查询的处理.


SQL> select to_char(strvalue) as Value from table(fn_split('aa,bb,cc',','));

VALUE
-------------------------------------------------------------------------------
aa
bb
cc

热心网友 时间:2022-05-01 08:08

info表的use字段会有重复的吗比如userA@userA,这样算一个还是2个?
如果没有重复或只算一个的话可以这么统计,不过效率是慢点....
select userID,(select count(1) from info where userID like '%' || trim(a.userID) || '%') from user a;

热心网友 时间:2022-05-01 09:42

select count * as num1 from info where user like '%userA%';
select count * as num2 from info where user like '%userB%';
select count * as num3 from info where user like '%userC%';

热心网友 时间:2022-05-01 11:34

select 字段A,字段B,字段C,字段D……,sum(统计字段) from 表名称 group by 字段A,字段B,字段C,字段D……

热心网友 时间:2022-05-01 13:42

我有点不大明白,什么是每个用户的总数量,你方便把两个原表的贴出来吗?
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
为什么来大姨妈胸会胀 少儿学什么舞蹈 青年学什么舞蹈好 成年人学什么舞蹈 福州企业最低工资标准 2013年厦门的底薪是多少 生产要素的需求有哪些性质 生产要素的需求有何特点? 什么是生产要素需求 微观经济学要素需求什么是条件要素需求?它和要素需求有什么不同?_百度... 还没有录取结果,请耐心等待是什么意思? 在线客服系统使用起来功能怎么样? 无录取信息,是没被录取吗? 在线客服系统是怎么个用法啊? 高考志愿录取查询显示没有录取信息是什么意思 高考录取查询时出现“暂无录取情况”是什么意思?是还没公布还是没考上? 高考录取结果查询显示没有录取结果是怎么回事 同学都已经查到了录取结果,显示还没有录取结果信息,是什么意思,是都没有被录取,还是结果还没有出来? 没有录取结果信息是什么意思 海底捞火锅底料保质期多久 苹果7plus里的照片为什么要自动上传? 苹果手机相册里有无法上传怎么解决? 苹果6s照片里一直显示上传怎么办? iphone 4s照片中正在上传是什么意思? iPhone 的照片图库无法上传到iCloud ,一直显示“正在上传632个项目”,这是怎么回事?_百度问一问 咸鱼遇到纠纷,该怎么处理 苹果手机照片突然被分享且已经是上传状态,怎么取消并且关闭? 苹果手机照片一直显示正在上传是怎么回事? 函数y=-x&#x00B2;+2x+3的图像的顶点坐标是 在闲鱼上遇到无赖买家怎么办? 在线客服系统怎么提升咨询率? 录取查询结 果是:还没有录取结果信息,是没被录取吗? 求助:如何在oracle中统计分组统计出现频率 河北省本科提前批A高考录取结果显示“还没有录取信息”是什么意思? 客服系统搭建该怎么做好? Oracle 数据库的分组统计问题 一直查不到录取结果信息是怎么回事? 网站客服系统怎么搭建? 求Oracle分组统计数量的sql怎么写,需求如下 高考显示暂无录取信息是什么意思?录取过了两天都没消息 怎么办啊?_百度问一问 在线客服系统怎么选择?用过的讲 oracle 怎么实现某月中按每周来分组统计 高考录取查询显示当前尚无您的录取信息这是怎么回事,学长学姐们, 客好用在线客服系统怎么样? oracle怎么按个数分组 高考录取查询时显示“暂无录取信息是什么意思” 无 Oracle如何得到分组统计结果的记录数 在线客服系统怎么选? 高考录取查询时显示“暂无录取信息是什么意思”? oracle 按照俩个字段俩次分组统计