成都网站建设设计

将想法与焦点和您一起共享

oracle数据怎么分组,数据分组怎么分组

oracle怎么按个数分组

SELECT MAX(AA.GROUPS), AA.TYPE_ID

公司主营业务:成都网站建设、做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出镇坪免费做网站回馈大家。

FROM (SELECT TRUNC((ROWNUM - 1) / 12) + 1 AS GROUPS,

MAX(A.TYPE_ID) TYPE_ID

FROM TABLENAME A

GROUP BY TRUNC((ROWNUM - 1) / 12) + 1

ORDER BY GROUPS) AA

GROUP BY AA.TYPE_ID

HAVING COUNT(1) 1;

oracle怎么根据一个数分组

首先你的starttime是什么类型的,数字?字符?还是时间?

要出来08:00-08:30这种结果简单,只要查询的时候加一个关联就可以,

比如select starttime||'-'||endtime from table.当然试过是时间的字段类型,比如date什么的,那就转换成字符型的,反正现在看来主要是字符型。

再说分组,分组可以用case when手动分组。

按照你给的图片个人觉得可以这么分

select case when starttime=0800 and endtime=10:00 then 1

when starttime=0900 and endtime=12:00 then 2

when starttime=1330 and endtime=15:30 then 3

when starttime=1530 and endtime=17:30 then 4

end 分组, starttime||'-'||endtime from table

这个语句中的具体写法,可能会因为数据类型的原因什么的,导致语句不能直接用,需要转换一下数据类型,但是大体上的意思和写法就是这样了。

Oracle数据库按时间进行分组统计数据的方法

Oracle按不同时间分组统计的sql

如下表table1:

日期(exportDate)

数量(amount)

--------------

-----------

14-2月

-08

20

10-3月

-08

2

14-4月

-08

6

14-6月

-08

75

24-10月-09

23

14-11月-09

45

04-8月

-10

5

04-9月

-10

44

04-10月-10

88

注意:为了显示更直观,如下查询已皆按相应分组排序

1.按年份分组

select

to_char(exportDate,'yyyy'),sum(amount)

from

table1

group

by

to_char(exportDate,'yyyy');

年份

数量

-----------------------------

2009

68

2010

137

2008

103

2.按月份分组

select

to_char(exportDate,'yyyy-mm'),sum(amount)

from

table1

group

by

to_char(exportDate,'yyyy-mm')

order

by

to_char(exportDate,'yyyy-mm');

月份

数量

-----------------------------

2008-02

20

2008-03

2

2008-04

6

2008-06

75

2009-10

23

2009-11

45

2010-08

5

2010-09

44

2010-10

88

3.按季度分组

select

to_char(exportDate,'yyyy-Q'),sum(amount)

from

table1

group

by

to_char(exportDate,'yyyy-Q')

order

by

to_char(exportDate,'yyyy-Q');

季度

数量

------------------------------

2008-1

22

2008-2

81

2009-4

68

2010-3

49

2010-4

88

4.按周分组

select

to_char(exportDate,'yyyy-IW'),sum(amount)

from

table1

group

by

to_char(exportDate,'yyyy-IW')

order

by

to_char(exportDate,'yyyy-IW');

数量

------------------------------

2008-07

20

2008-11

2

2008-16

6

2008-24

75

2009-43

23

2009-46

45

2010-31

5

2010-35

44

2010-40

88

PS:Oracle按时间段分组统计

想要按时间段分组查询,首先要了解level,connect

by,oracle时间的加减.

关于level这里不多说,我只写出一个查询语句:

----level

是一个伪例

select

level

from

dual

connect

by

level

=10

---结果:

1

2

3

4

5

6

7

8

9

10

oracle时间的加减看看试一下以下sql语句就会知道:

select

sysdate

-1

from

dual

----结果减一天,也就24小时

select

sysdate-(1/2)

from

dual

-----结果减去半天,也就12小时

select

sysdate-(1/24)

from

dual

-----结果减去1

小时

select

sysdate-((1/24)/12)

from

dual

----结果减去5分钟

select

sydate-(level-1)

from

dual

connect

by

level=10

---结果是10间隔1天的时间

下面是本次例子:

select

dt,

count(satisfy_degree)

as

num

from

T_DEMO

i

,

(select

sysdate

-

(level-1)

*

2

dt

from

dual

connect

by

level

=

10)

d

where

i.satisfy_degree='satisfy_1'

and

i.insert_timedt

and

i.insert_time

d.dt-2

group

by

d.dt

例子中的sysdate

-

(level-1)

*

2得到的是一个间隔是2天的时间

group

by

d.dt

也就是两天的时间间隔分组查询

自己实现例子:

create

table

A_HY_LOCATE1

(

MOBILE_NO

VARCHAR2(32),

LOCATE_TYPE

NUMBER(4),

AREA_NO

VARCHAR2(32),

CREATED_TIME

DATE,

AREA_NAME

VARCHAR2(512),

);

select

(sysdate-13)-(level-1)/4

from

dual

connect

by

level=34

--从第一条时间记录开始(sysdate-13)为表中的最早的日期,“34”出现的分组数(一天按每六个小时分组

就应该为4)

一下是按照每6个小时分组

select

mobile_no,area_name,max(created_time

),dt,

count(*)

as

num

from

a_hy_locate1

i

,

(select

(sysdate-13)-(level-1)/4

dt

from

dual

connect

by

level

=

34)

d

where

i.locate_type

=

1

and

i.created_timedt

and

i.created_time

d.dt-1/4

group

by

mobile_no,area_name,d.dt

另外一个方法:

--按六小时分组

select

trunc(to_number(to_char(created_time,

'hh24'))

/

6),count(*)

from

t_test

where

created_time

trunc(sysdate

-

40)

group

by

trunc(to_number(to_char(created_time,

'hh24'))

/

6)

--按12小时分组

select

trunc(to_number(to_char(created_time,

'hh24'))

/

6),count(*)

from

t_test

where

created_time

trunc(sysdate

-

40)

group

by

trunc(to_number(to_char(created_time,

'hh24'))

/

6)

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

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

oracle数据库的分组查询的语句怎么写

oracle数据库的分组查询语句,主要是根据一个字段,使用关键字group

by来分组,如下代码:

select to_char(date_column, 'yyyy-Q'),count(*)

from xxx

where date_column between '01-Jan-2007' and '31-Dec-2009'

group by to_char(date_column, 'yyyy-Q')//分组查询

oracle中的分组函数有哪些,具体怎么用?

常用的函数有:

1、COUNT ()返回查寻的行数

例如:select count(*) from table;

2、MAX() 返回表达式的最大值

例如:select a, max(b) from table group by a;

3、MIN() 返回表达式的最小值

例如:select a, min(b) from table group by a;

4、SUM() 返回表达式的总合

例如:select a, sum(b) from table group by a;

5、AVG() 返回表达式的平均值

例如:select a, avg(b) from table group by a。

函数

函数在数学上的定义:给定一个非空的数集A,对A施加对应法则f,记作f(A),得到另一数集B,也就是B=f(A).那么这个关系式就叫函数关系式,简称函数。


分享文章:oracle数据怎么分组,数据分组怎么分组
网页网址:http://chengdu.cdxwcx.cn/article/dsissdd.html