oracle如何分类小计,oracle小计用什么函数

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

CREATE  TABLE  info (

大埔网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、自适应网站建设等网站项目制作,到程序开发,运营维护。创新互联于2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联

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

oracle 中如何将查询到的i.suc_amount按x分别进行小计,最后总计,应该是用rollup,sql应该怎么改?

你试试

Select o.org_desc || '_' || i.b_company x,

i.trade_time,

i.cust_name,

i.order_id,

sum(i.suc_amount) over(partition by o.org_desc || '_' || i.b_company),

i.plug_id,

i.b_company,

sum(i.suc_amount) over()

from t_ec_trade_info i, t_ec_org_mapping o

where i.b_company = o.org_biz_numb

and (i.b_company is not null)

order by i.b_company desc

oracle 小计合计查询问题?

不知道你所谓小计是什么意思,你可以看看下面的效果

select case when ID is null then '合计'

when CODE is null then '小计' else to_char(ID) end,

CODE,total

from (

select ID,CODE,sum(NUMBER) total from tttt

group by rollup(ID,CODE)

)

如果不是上面的意思 那么用开窗函数看看

SELECT ID,CODE,NUMBER

sum(NUMBER) OVER(partition by ID,CODE ORDER BY NUMBER ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW)

FROM tttt;

oracle查询分类汇总怎么写

试试这样:

SELECT a.Deptcode 部门,

a.id ID,

a.NAME 姓名,

a.ITEM 物品名称,

sum(a.QTY) 数量,

sum(a.COST) 金额

from itemlist A

where a.Fee_Date=TO_DATE('2015-3-29','YY-MM-DD')

AND a.FEE_DATE=TO_DATE('2015-3-30','YY-MM-DD')

AND a.QTY'0'

group by a.Deptcode ,

a.id ,

a.NAME ,

a.ITEM

order by 6 desc

oracle的select语句实现分类汇总

Oracle Select语句的作用是在表单中查询数据,本文将为大家带来Select语句的详细用法介绍。

SELECT语句使用方法

在Oracle中,表是由列和行组成。 例如,示例数据库中的customers表具有以下列:customer_id,name,address,website和credit_limit。customers表中这些列中也有对应的数据。

要从表的一个或多个列(column_1,column_2,…,column_n)中检索数据,请使用以下语法的SELECT语句:

在这个SELECT语句中:

首先,需要指定要查询数据的表名。

其次,指定想要返回数据的列。 如果需要返回多个列,则需要用逗号(,)将这些列分隔。

注意,SELECT语句非常复杂,由许多子句组成,如ORDER BY,GROUP BY,HAVING,JOIN。 为了简单起见,在本教程中,我们只关注SELECT和FROM子句的用法。

教程来源:树懒学堂_一站式数据知识平台_Oracle Select语句

Oracle数据库分类汇总方法

如果是分别显示,可以写成两条语句:

select

avg(salary),deptno

from

a

group

by

deptno;

select

avg(salary),companyno

from

a

group

by

companyno;

如果需要用一条SQL实现,使用CUBE函数:

select

avg(salary),deptno,companyno

from

a

group

by

cube(deptno,companyno);


标题名称:oracle如何分类小计,oracle小计用什么函数
分享路径:http://myzitong.com/article/dsisgpi.html