zoukankan      html  css  js  c++  java
  • heap表按字符串和数值型排序规则

    SQL> create user scan identified by scan default tablespace users;
    
    User created.
    
    SQL> grant dba to scan;
    
    Grant succeeded.
    
    
    
    create table t1  (id char(10) primary key,a1 char(10),a2 char(10));  
    
    
    begin 
    for i in 1 .. 25
    loop 
    insert into t1 values(i,i,'a'||i); 
    end loop 
    ; 
    commit; 
    end; 
    
    
    BEGIN
      DBMS_STATS.GATHER_TABLE_STATS(ownname          => 'SCAN',
                                    tabname          => 'T1',
                                    estimate_percent => 100,
                                    method_opt       => 'for all columns size repeat',
                                    no_invalidate    => FALSE,
                                    degree           => 8,
                                    cascade          => TRUE);
    END;
    / 
    
    
    
    
    create table t2 (id int primary key,a1 char(10),a2 char(10))organization index; 
    
    
    begin 
    for i in 1 .. 25 
    loop 
    insert into t2 values(i,i,'a'||i); 
    end loop 
    ; 
    commit; 
    end;
    
    
    BEGIN
      DBMS_STATS.GATHER_TABLE_STATS(ownname          => 'SCAN',
                                    tabname          => 'T2',
                                    estimate_percent => 100,
                                    method_opt       => 'for all columns size repeat',
                                    no_invalidate    => FALSE,
                                    degree           => 8,
                                    cascade          => TRUE);
    END;
    / 
    
    
    
    先分别dump下t1和t2表:  t1 heap  t2 iot
    
    SQL> select  TABLE_NAME,TABLESPACE_NAME,CLUSTER_NAME, IOT_NAME from user_tables;
    
    TABLE_NAME		       TABLESPACE_NAME		      CLUSTER_NAME		     IOT_NAME
    ------------------------------ ------------------------------ ------------------------------ ------------------------------
    T1			       USERS
    T2
    
    
    
    SQL>  select object_name,object_id from user_objects;
    
    OBJECT_NAME			OBJECT_ID
    ------------------------------ ----------
    SYS_C00147516			   260450
    T2				   260451
    T1				   260449
    SYS_IOT_TOP_260451		   260452
    
    
    
    
    SQL>  select index_name,INDEX_TYPE,TABLE_OWNER,TABLE_NAME,table_type from user_indexes;
    
    INDEX_NAME		       INDEX_TYPE		   TABLE_OWNER			  TABLE_NAME			 TABLE_TYPE
    ------------------------------ --------------------------- ------------------------------ ------------------------------ -----------
    SYS_C00147516		       NORMAL			   SCAN 			  T1				 TABLE
    SYS_IOT_TOP_260451	       IOT - TOP		   SCAN 			  T2				 TABLE
    
    
    
    2.将索引dump到trace文件中
    SQL> select value from v$diag_info where name='Default Trace File';
    
    VALUE
    --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
    /u01/app/oracle/diag/rdbms/ncdb/podinndb/trace/podinndb_ora_28524.trc
    
    SQL> alter session set events 'immediate trace name treedump level 260450';
    
    会话已更改。
    
    
    ----- begin tree dump
    leaf: 0x100008b 16777355 (0: nrow: 25 rrow: 25)
    ----- end tree dump
    
    
    SQL> select index_name, PREFIX_LENGTH, BLEVEL, LEAF_BLOCKS from user_indexes where index_name='SYS_C00147516';
    
    INDEX_NAME		       PREFIX_LENGTH	 BLEVEL LEAF_BLOCKS
    ------------------------------ ------------- ---------- -----------
    SYS_C00147516					      0 	  1
    
    
    
    
    SQL> select dbms_utility.data_block_address_file('16777355') FILE_ID,
           dbms_utility.data_block_address_block('16777355') BLOCK_ID
      from dual;   2    3  
    
       FILE_ID   BLOCK_ID
    ---------- ----------
    	 4	  139
    
    
    
    SQL>  select header_file,header_block from dba_segments where segment_name='SYS_C00147516';
    
    HEADER_FILE HEADER_BLOCK
    ----------- ------------
    	  4	     138
    
    
    
    select dbms_utility.data_block_address_file(16777355)fno,
    dbms_utility.data_block_address_block(16777355) bkno from dualSQL>   2  
      3  ;
    
           FNO	 BKNO
    ---------- ----------
    	 4	  139;  
    
    SQL> alter system dump datafile 4 block 139;
    
    
    
    
    row#0[8013] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 00
    col 0; len 10; (10):  31 20 20 20 20 20 20 20 20 20      ---表示1
    row#1[7842] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 09
    col 0; len 10; (10):  31 30 20 20 20 20 20 20 20 20      ---表示10
    row#2[7823] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 0a
    col 0; len 10; (10):  31 31 20 20 20 20 20 20 20 20      --表示11
    row#3[7804] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 0b
    col 0; len 10; (10):  31 32 20 20 20 20 20 20 20 20      --表示12
    row#4[7785] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 0c
    col 0; len 10; (10):  31 33 20 20 20 20 20 20 20 20       --表示13
    row#5[7766] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 0d
    col 0; len 10; (10):  31 34 20 20 20 20 20 20 20 20       --表示14
    row#6[7747] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 0e
    col 0; len 10; (10):  31 35 20 20 20 20 20 20 20 20       --表示15
    row#7[7728] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 0f
    col 0; len 10; (10):  31 36 20 20 20 20 20 20 20 20       --表示16
    row#8[7709] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 10
    col 0; len 10; (10):  31 37 20 20 20 20 20 20 20 20       --表示17
    row#9[7690] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 11
    col 0; len 10; (10):  31 38 20 20 20 20 20 20 20 20       --表示18
    row#10[7671] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 12
    col 0; len 10; (10):  31 39 20 20 20 20 20 20 20 20        --表示19
    row#11[7994] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 01
    col 0; len 10; (10):  32 20 20 20 20 20 20 20 20 20         --表示2
    row#12[7652] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 13
    col 0; len 10; (10):  32 30 20 20 20 20 20 20 20 20          --表示20
    row#13[7633] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 14
    col 0; len 10; (10):  32 31 20 20 20 20 20 20 20 20           --表示21
    row#14[7614] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 15
    col 0; len 10; (10):  32 32 20 20 20 20 20 20 20 20          --表示22
    row#15[7595] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 16
    col 0; len 10; (10):  32 33 20 20 20 20 20 20 20 20         --表示23
    row#16[7576] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 17
    col 0; len 10; (10):  32 34 20 20 20 20 20 20 20 20         --表示24
    row#17[7557] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 18
    col 0; len 10; (10):  32 35 20 20 20 20 20 20 20 20         --表示25
    row#18[7975] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 02
    col 0; len 10; (10):  33 20 20 20 20 20 20 20 20 20         --表示3
    row#19[7956] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 03
    col 0; len 10; (10):  34 20 20 20 20 20 20 20 20 20           --表示4
    row#20[7937] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 04
    col 0; len 10; (10):  35 20 20 20 20 20 20 20 20 20            --表示5
    row#21[7918] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 05
    col 0; len 10; (10):  36 20 20 20 20 20 20 20 20 20           --表示6
    row#22[7899] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 06
    col 0; len 10; (10):  37 20 20 20 20 20 20 20 20 20           --表示7
    row#23[7880] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 07
    col 0; len 10; (10):  38 20 20 20 20 20 20 20 20 20           --表示8
    row#24[7861] flag: ------, lock: 2, len=19, data:(6):  01 00 00 85 00 08
    col 0; len 10; (10):  39 20 20 20 20 20 20 20 20 20           --表示9
    ----- end of leaf block dump -----
    End dump data blocks tsn: 4 file#: 4 minblk 139 maxblk 139
    
    
    DECLARE
       n   VARCHAR2 (2000);
    BEGIN
       DBMS_STATS.convert_raw_value ('35', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
       DBMS_STATS.convert_raw_value ('20', n);
       DBMS_OUTPUT.put_line (n);
    END;
    
    
    结论 heap表主键只有对应的列
    
    heap 表排序:
    SQL> select * from t1 order by t1.id;
    
    ID	   A1	      A2
    ---------- ---------- ----------
    1	   1	      a1
    10	   10	      a10
    11	   11	      a11
    12	   12	      a12
    13	   13	      a13
    14	   14	      a14
    15	   15	      a15
    16	   16	      a16
    17	   17	      a17
    18	   18	      a18
    19	   19	      a19
    
    ID	   A1	      A2
    ---------- ---------- ----------
    2	   2	      a2
    20	   20	      a20
    21	   21	      a21
    22	   22	      a22
    23	   23	      a23
    24	   24	      a24
    25	   25	      a25
    3	   3	      a3
    4	   4	      a4
    5	   5	      a5
    6	   6	      a6
    
    ID	   A1	      A2
    ---------- ---------- ----------
    7	   7	      a7
    8	   8	      a8
    9	   9	      a9
    
    25 rows selected.
    
    
    t1表 id列为字符串,排序是按字符串排序
    
    
    
    
    /***创建t3表改为数值型/
    
    create table t3  (id int primary key,a1 char(10),a2 char(10));  
    
    
    begin 
    for i in 1 .. 25
    loop 
    insert into t3 values(i,i,'a'||i); 
    end loop 
    ; 
    commit; 
    end; 
    
    BEGIN
      DBMS_STATS.GATHER_TABLE_STATS(ownname          => 'SCAN',
                                    tabname          => 'T3',
                                    estimate_percent => 100,
                                    method_opt       => 'for all columns size repeat',
                                    no_invalidate    => FALSE,
                                    degree           => 8,
                                    cascade          => TRUE);
    END;
    / 
    
    
    
    SQL>  select  TABLE_NAME,TABLESPACE_NAME,CLUSTER_NAME, IOT_NAME from user_tables;
    
    TABLE_NAME	     TABLESPACE_NAME		    CLUSTER_NAME		   IOT_NAME
    -------------------- ------------------------------ ------------------------------ ------------------------------
    T1		     USERS
    T3		     USERS
    T2
    
    
    SQL> select object_name,object_id from user_objects;
    
    OBJECT_NAME			OBJECT_ID
    ------------------------------ ----------
    SYS_C00147518			   260454
    T3				   260453
    SYS_IOT_TOP_260451		   260452
    T1				   260449
    T2				   260451
    SYS_C00147516			   260450
    
    6 rows selected.
    
    
    
    SQL>  select index_name,INDEX_TYPE,TABLE_OWNER,TABLE_NAME,table_type from user_indexes;
    
    INDEX_NAME		       INDEX_TYPE		   TABLE_OWNER			  TABLE_NAME	       TABLE_TYPE
    ------------------------------ --------------------------- ------------------------------ -------------------- -----------
    SYS_C00147516		       NORMAL			   SCAN 			  T1		       TABLE
    SYS_IOT_TOP_260451	       IOT - TOP		   SCAN 			  T2		       TABLE
    SYS_C00147518		       NORMAL			   SCAN 			  T3		       TABLE
    
    
    
    2.将索引dump到trace文件中
    SQL> select value from v$diag_info where name='Default Trace File';
    
    VALUE
    --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
    /u01/app/oracle/diag/rdbms/ncdb/podinndb/trace/podinndb_ora_29363.trc
    
    SQL> alter session set events 'immediate trace name treedump level 260454';
    
    会话已更改。
    
    
    ----- begin tree dump
    leaf: 0x10000a3 16777379 (0: nrow: 25 rrow: 25)
    ----- end tree dump
    
    SQL> select index_name, PREFIX_LENGTH, BLEVEL, LEAF_BLOCKS from user_indexes where index_name='SYS_C00147518';
    
    INDEX_NAME		       PREFIX_LENGTH	 BLEVEL LEAF_BLOCKS
    ------------------------------ ------------- ---------- -----------
    SYS_C00147518					      0 	  1
    
    
    
    
    SQL> select dbms_utility.data_block_address_file('16777379') FILE_ID,
           dbms_utility.data_block_address_block('16777379') BLOCK_ID
      from dual;   2    3  
    
       FILE_ID   BLOCK_ID
    ---------- ----------
    	 4	  163
    
    
    SQL>  select header_file,header_block from dba_segments where segment_name='SYS_C00147518';
    
    HEADER_FILE HEADER_BLOCK
    ----------- ------------
    	  4	     162
    
    SQL> select dbms_utility.data_block_address_file(16777379)fno,
    dbms_utility.data_block_address_block(16777379) bkno from dual  2  ;
    
           FNO	 BKNO
    ---------- ----------
    	 4	  163
    
    SQL> alter system dump datafile 4 block 163;
    
    
    
    row#0[8021] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 00
    col 0; len 2; (2):  c1 02   ---表示1
    row#1[8010] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 01
    col 0; len 2; (2):  c1 03   --表示2
    row#2[7999] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 02
    col 0; len 2; (2):  c1 04   --表示3
    row#3[7988] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 03
    col 0; len 2; (2):  c1 05   --表示4
    row#4[7977] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 04
    col 0; len 2; (2):  c1 06   --表示5
    row#5[7966] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 05
    col 0; len 2; (2):  c1 07
    row#6[7955] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 06
    col 0; len 2; (2):  c1 08
    row#7[7944] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 07
    col 0; len 2; (2):  c1 09
    row#8[7933] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 08
    col 0; len 2; (2):  c1 0a
    row#9[7922] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 09
    col 0; len 2; (2):  c1 0b
    row#10[7911] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 0a
    col 0; len 2; (2):  c1 0c
    row#11[7900] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 0b
    col 0; len 2; (2):  c1 0d
    row#12[7889] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 0c
    col 0; len 2; (2):  c1 0e
    row#13[7878] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 0d
    col 0; len 2; (2):  c1 0f
    row#14[7867] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 0e
    col 0; len 2; (2):  c1 10
    row#15[7856] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 0f
    col 0; len 2; (2):  c1 11
    row#16[7845] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 10
    col 0; len 2; (2):  c1 12
    row#17[7834] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 11
    col 0; len 2; (2):  c1 13
    row#18[7823] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 12
    col 0; len 2; (2):  c1 14
    row#19[7812] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 13
    col 0; len 2; (2):  c1 15
    row#20[7801] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 14
    col 0; len 2; (2):  c1 16
    row#21[7790] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 15
    col 0; len 2; (2):  c1 17
    row#22[7779] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 16
    col 0; len 2; (2):  c1 18  --表示23
    row#23[7768] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 17
    col 0; len 2; (2):  c1 19    --表示24
    row#24[7757] flag: ------, lock: 2, len=11, data:(6):  01 00 00 9d 00 18
    col 0; len 2; (2):  c1 1a    --表示25
    ----- end of leaf block dump -----
    End dump data blocks tsn: 4 file#: 4 minblk 163 maxblk 163
    
    
    
    declare    
       n number;    
     begin    
       dbms_stats.convert_raw_value('c102',    
                                    n);    
       dbms_output.put_line(n);    
     end; 
    
    SQL> select * from t3 order by t3.id;
    
    	ID A1	      A2
    ---------- ---------- ----------
    	 1 1	      a1
    	 2 2	      a2
    	 3 3	      a3
    	 4 4	      a4
    	 5 5	      a5
    	 6 6	      a6
    	 7 7	      a7
    	 8 8	      a8
    	 9 9	      a9
    	10 10	      a10
    	11 11	      a11
    
    	ID A1	      A2
    ---------- ---------- ----------
    	12 12	      a12
    	13 13	      a13
    	14 14	      a14
    	15 15	      a15
    	16 16	      a16
    	17 17	      a17
    	18 18	      a18
    	19 19	      a19
    	20 20	      a20
    	21 21	      a21
    	22 22	      a22
    
    	ID A1	      A2
    ---------- ---------- ----------
    	23 23	      a23
    	24 24	      a24
    	25 25	      a25
    
    25 rows selected.
    
    
    
    结论 字符串和数值型 排序方式不同

  • 相关阅读:
    030-PHP日期查询函数
    029-PHP取随机数
    028-PHP常用数学函数abs和acos和asin
    027-PHP编码和解码函数base64
    026-PHP常用字符串函数(三)
    025-PHP常用字符串函数(二)
    024-PHP常用字符串函数(一)
    023-PHP常用数组函数
    022-PHP数组排序asort
    021-PHP常用的数值类型判断函数
  • 原文地址:https://www.cnblogs.com/zhaoyangjian724/p/6199032.html
Copyright © 2011-2022 走看看