很急!有没有知道informix中row_number over 函数怎么用啊

很急!有没有知道informix中row_number over 函数怎么用啊,第1张

row_number() OVER (PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的)

与rownum的区别在于:使用rownum进行排序的时候是先对结果集加入伪列rownum然后再进行排序,而此函数在包含排序从句后是先排序再计算行号码.

row_number()和rownum差不多,功能更强一点(可以在各个分组内从1开时排序).

rank()是跳跃排序,有两个第二名时接下来就是第四名(同样是在各个分组内).

dense_rank()l是连续排序,有两个第二名时仍然跟着第三名。相比之下row_number是没有重复值的 .

lag(arg1,arg2,arg3):

arg1是从其他行返回的表达式

arg2是希望检索的当前行分区的偏移量。是一个正的偏移量,时一个往回检索以前的行的数目。

arg3是在arg2表示的数目超出了分组的范围时返回的值。

看几个SQL语句:

语句一:

select row_number() over(order by sale/cnt desc) as sort, sale/cnt

from (

select -60 as sale,3 as cnt from dual union

select 24 as sale,6 as cnt from dual union

select 50 as sale,5 as cnt from dual union

select -20 as sale,2 as cnt from dual union

select 40 as sale,8 as cnt from dual);

执行结果:

SORT SALE/CNT

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

1 10

2 5

3 4

4 -10

5 -20

语句二:查询员工的工资,按部门排序

select ename,sal,row_number() over (partition by deptno order by sal desc) as sal_order from scottemp;

执行结果:

ENAME SAL SAL_ORDER

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

KING 5000 1

CLARK 2450 2

MILLER 1300 3

SCOTT 3000 1

FORD 3000 2

JONES 2975 3

ADAMS 1100 4

SMITH 800 5

BLAKE 2850 1

ALLEN 1600 2

TURNER 1500 3

WARD 1250 4

MARTIN 1250 5

JAMES 950 6

已选择14行。

语句三:查询每个部门的最高工资

select deptno,ename,sal from

(select deptno,ename,sal,row_number() over (partition by deptno order by sal desc) as sal_order

from scottemp) where sal_order <2;

执行结果:

DEPTNO ENAME SAL

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

10 KING 5000

20 SCOTT 3000

30 BLAKE 2850

已选择3行。

语句四:

select deptno,sal,rank() over (partition by deptno order by sal) as rank_order from scottemp order by deptno;

执行结果:

DEPTNO SAL RANK_ORDER

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

10 1300 1

10 2450 2

10 5000 3

20 800 1

20 1100 2

20 2975 3

20 3000 4

20 3000 4

30 950 1

30 1250 2

30 1250 2

30 1500 4

30 1600 5

30 2850 6

已选择14行。

语句五:

select deptno,sal,dense_rank() over(partition by deptno order by sal) as dense_rank_order from scottemp order by deptn;

执行结果:

DEPTNO SAL DENSE_RANK_ORDER

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

10 1300 1

10 2450 2

10 5000 3

20 800 1

20 1100 2

20 2975 3

20 3000 4

20 3000 4

30 950 1

30 1250 2

30 1250 2

30 1500 3

30 1600 4

30 2850 5

已选择14行。

load from 'testcsv' delimiter ',' insert into test;

这里的testcsv可以指定路径的,如果是在当前路径执行导入命令,就不用写了。

select 时间, sum(case when 时间 like '200711' then 金额 else 0 end),

sum(case when 时间 like '200712' then 金额 else 0 end)

from tab

group by substring(时间, 1, 7)

substring(时间, 1, 7)--->不同数据库可能需要你坐响应转换,就是拿到年和月份就可以了

使用命令onstat -查看当前数据库状态,通常有以下几种状态:

l On-Line:联机状态

此状态允许用户联机访问数据库,正常情况下OnLine启动后应处于此状态。

l shared memory not initialized:脱机状态

通常OnLine关闭后处于此状态。

l Fast Recovery:快速恢复状态

每次OnLine启动时,都要读取物理/逻辑日志,回滚上次OnLine关闭时未提交的事务和未释放的锁等,将数据库快速恢复到物理和逻辑都一致的状态。

快速恢复是过渡状态,时间很短,恢复无错后即进入On-Line状态。

l Quiescent:静止状态

处于此状态不允许用户访问数据库。通常是数据库管理员在静止状态下进行一些数据库参数的调整(如日志和缓冲区大小等)。

32 启动OnLine

如果数据库处于脱机状态,可使用命令oninit启动OnLine。

启动后,使用onstat -命令查看数据库状态,若不处于联机状态,可检查日志文件$INFORMIXDIR/onlinelog确认失败原因。

33 关闭OnLine

使用命令onmode -ky关闭数据库。

4 dbaccess使用

执行dbaccess命令,可选择相应的数据库,并在该库上执行SQL语句或其它的 *** 作。

41 数据库 *** 作

Database菜单:选择/断开数据库

Select: 选择数据库

cLose: 关闭与当前数据库的连接

Connection:连接/断开数据库服务器

Connect: 连接数据库服务器,提示“Select Database Server”时选择目标数据库服务器;

User Name: 如以运行当前用户连接数据库,可直接回车;否则输入连接数据库服务器的用户名称;

Password: 用户口令;

Select Database: 选择所要连接的数据库

以上就是关于很急!有没有知道informix中row_number over 函数怎么用啊全部的内容,包括:很急!有没有知道informix中row_number over 函数怎么用啊、informix的load语句使用方法、每个月份分组统计求和 group by等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9289551.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存