WEB开发网
开发学院数据库Oracle 菜鸟学oracle - 用PL/SQL画直方图 阅读

菜鸟学oracle - 用PL/SQL画直方图

 2007-05-12 12:22:48 来源:WEB开发网   
核心提示:现在用的库里有一个MV是统计按小时的访问量的,数据如下代码:SQL> select * from mv_time_stat;TIMECNT-- --01871512343194195206507107868291342101854111292121416131180141217151573161785171469

现在用的库里有一个MV是统计按小时的访问量的,数据如下

代码:
SQL> select * from mv_time_stat;
   TIME    CNT
---------- ----------
    0    187
    1    51
    2    34
    3    19
    4    19
    5    20
    6    50
    7    107
    8    682
    9   1342
    10   1854
    11   1292
    12   1416
    13   1180
    14   1217
    15   1573
    16   1785
    17   1469
    18   1892
    19   1907
    20   1602
    21   1540
    22   1013
    23    441
24 rows selected.

某年月日,突发奇想,打算在sqlplus下面按上面的数据画个直方图出来,首先写了个竖列的(因为好写):

代码:
SQL> COL Time FORMAT A7
SQL> SELECT LPAD(DECODE(TIME,TO_CHAR(SYSDATE,'HH24'),'NOW: '||TO_CHAR(TIME),TO_CHAR(TIME)),7,' ') AS "Time",
 2 SUBSTR('|'||LPAD('> '||CNT,CEIL(CNT/A.TOTAL*300)+LENGTH(TO_CHAR(CNT))+1,'-'),1,35) AS "  Count per hour"
 3 FROM MV_TIME_STAT,(SELECT SUM(CNT) AS TOTAL FROM MV_TIME_STAT) A;
COL Time CLEAR
Time    Count per hour
------- ----------------------------------------------------------------------
   0 |--> 187
   1 |> 51
   2 |> 34
   3 |> 19
   4 |> 19
   5 |> 20
   6 |> 50
   7 |-> 107
NOW: 8 |---------> 682
   9 |-----------------> 1342
  10 |------------------------> 1854
  11 |-----------------> 1292
  12 |------------------> 1416
  13 |---------------> 1180
  14 |----------------> 1217
  15 |--------------------> 1573
  16 |-----------------------> 1785
  17 |-------------------> 1469
  18 |-------------------------> 1892
  19 |-------------------------> 1907
  20 |---------------------> 1602
  21 |--------------------> 1540
  22 |-------------> 1013
  23 |-----> 441
24 rows selected.

1 2  下一页

Tags:菜鸟 oracle PL

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接