最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

Oracle12c學(xué)習(xí)系列之—Rowlimits&InvisibleColumn

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-09 13:03:29
文檔

Oracle12c學(xué)習(xí)系列之—Rowlimits&InvisibleColumn

Oracle12c學(xué)習(xí)系列之—Rowlimits&InvisibleColumn:本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng): 轉(zhuǎn)載自love wife love life —Roger 的Oracle技術(shù)博客 本文鏈接地址: Oracle 12c學(xué)習(xí)系列之—Row limits Invisible Column Oracle 12c 引入了row limits的特性,玩Mysql的人都知道這個,然而Ora
推薦度:
導(dǎo)讀Oracle12c學(xué)習(xí)系列之—Rowlimits&InvisibleColumn:本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng): 轉(zhuǎn)載自love wife love life —Roger 的Oracle技術(shù)博客 本文鏈接地址: Oracle 12c學(xué)習(xí)系列之—Row limits Invisible Column Oracle 12c 引入了row limits的特性,玩Mysql的人都知道這個,然而Ora

本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng): 轉(zhuǎn)載自love wife love life —Roger 的Oracle技術(shù)博客 本文鏈接地址: Oracle 12c學(xué)習(xí)系列之—Row limits Invisible Column Oracle 12c 引入了row limits的特性,玩Mysql的人都知道這個,然而Oracle卻一直沒有這個功能

本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng): 轉(zhuǎn)載自love wife & love life —Roger 的Oracle技術(shù)博客

本文鏈接地址: Oracle 12c學(xué)習(xí)系列之—Row limits & Invisible Column

Oracle 12c 引入了row limits的特性,玩Mysql的人都知道這個,然而Oracle卻一直沒有這個功能,不過在12c中終于實(shí)現(xiàn)了。

SQL> show con_name
CON_NAME
------------------------------
PDBORCL
SQL> create table test_lim as select * from dba_objects;
Table created.
SQL> select count(1) from test_lim;
COUNT(1)
----------
90929
SQL> col owner for a10
SQL> col objecT_name for a30
SQL> select object_id,owner,object_name from test_lim order by 1
2 fetch first 5 rows only;
OBJECT_ID OWNER OBJECT_NAME
---------- ---------- ------------------------------
2 SYS C_OBJ#
3 SYS I_OBJ#
4 SYS TAB$
5 SYS CLU$
6 SYS C_TS#
SQL> l
1 select object_id,owner,object_name from test_lim order by 1
2* fetch first 5 rows only
SQL> /
Execution Plan
----------------------------------------------------------
Plan hash value: 1929006521
---------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes |TempSpc| Cost (%CPU)| Time |
---------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 5 | 855 | | 1290 (1)| 00:00:01 |
|* 1 | VIEW | | 5 | 855 | | 1290 (1)| 00:00:01 |
|* 2 | WINDOW SORT PUSHED RANK| | 90929 | 3196K| 4288K| 1290 (1)| 00:00:01 |
| 3 | TABLE ACCESS FULL | TEST_LIM | 90929 | 3196K| | 426 (1)| 00:00:01 |
---------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("from$_subquery$_002"."rowlimit_$$_rownumber"<=5)
2 - filter(ROW_NUMBER() OVER ( ORDER BY "OBJECT_ID")<=5)

而且你還可以查詢其中的某幾行數(shù)據(jù),例如我想查詢第100-110 行數(shù)據(jù)。

SQL> select objecT_id, owner, object_name
2 from test_lim
3 order by 1 offset 110 rows fetch next 10 rows only;
OBJECT_ID OWNER OBJECT_NAME
---------- ---------- ------------------------------
112 SYS I_COLTYPE1
113 SYS I_COLTYPE2
114 SYS SUBCOLTYPE$
115 SYS I_SUBCOLTYPE1
116 SYS NTAB$
117 SYS I_NTAB1
118 SYS I_NTAB2
119 SYS I_NTAB3
120 SYS REFCON$
121 SYS I_REFCON1
10 rows selected.

注意,它這里的offset是根據(jù)行號(rownum來的)。如果你這樣覺得不明白,這樣查詢就明白了,如下:

SQL> select rownum,a.objecT_id, a.owner, a.object_name
2 from test_lim a
3 order by 1 offset 110 rows fetch next 10 rows only;
ROWNUM OBJECT_ID OWNER OBJECT_NAME
---------- ---------- ---------- ------------------------------
111 112 SYS I_COLTYPE1
112 113 SYS I_COLTYPE2
113 114 SYS SUBCOLTYPE$
114 115 SYS I_SUBCOLTYPE1
115 116 SYS NTAB$
116 117 SYS I_NTAB1
117 118 SYS I_NTAB2
118 119 SYS I_NTAB3
119 120 SYS REFCON$
120 121 SYS I_REFCON1
10 rows selected.

除了前面fetch和offset用法之外,還有一個percent選項(xiàng),如下:

SQL> select count(1) from (
2 select objecT_id, owner, object_name
3 from test_lim a order by 1
4 fetch first 1 percent rows only);
COUNT(1)
----------
910
SQL> select objecT_id, owner, object_name
2 from test_lim a
3 order by 1 fetch first 0.01 percent rows only;
OBJECT_ID OWNER OBJECT_NAME
---------- ---------- ------------------------------
2 SYS C_OBJ#
3 SYS I_OBJ#
4 SYS TAB$
5 SYS CLU$
6 SYS C_TS#
7 SYS I_TS#
8 SYS C_FILE#_BLOCK#
9 SYS I_FILE#_BLOCK#
10 SYS C_USER#
11 SYS I_USER#
10 rows selected.

我們可以返回指定比例的數(shù)據(jù),注意,Oracle這里是取整的,而且不是四舍五入的原則。

SQL> set autot traceonly
SQL> l
1 select objecT_id, owner, object_name
2 from test_lim a
3* order by 1 fetch first 0.01 percent rows only
SQL> /
10 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 547893470
----------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes |TempSpc| Cost (%CPU)| Time |
----------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 90929 | 15M| | 1290 (1)| 00:00:01 |
|* 1 | VIEW | | 90929 | 15M| | 1290 (1)| 00:00:01 |
| 2 | WINDOW SORT | | 90929 | 3196K| 4288K| 1290 (1)| 00:00:01 |
| 3 | TABLE ACCESS FULL| TEST_LIM | 90929 | 3196K| | 426 (1)| 00:00:01 |
----------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("from$_subquery$_002"."rowlimit_$$_rownumber"<=CEIL("from$_subquer
y$_002"."rowlimit_$$_total"*0.01/100))

可以清楚的看到Oracle的過程,其實(shí)是進(jìn)行了一個復(fù)雜的filter操作。

+++++++++ Invisible column +++++++++++++

在Oracle 11g版本中,引入了invisible Index特性,在12c中更進(jìn)一步,可以讓column也不可見,即invisible column特性。

SQL> create table test_visible as select owner,object_id
2 from dba_objects where object_id < 10;
Table created.
SQL> alter table test_visible modify (owner invisible);
Table altered.
SQL> desc test_visible
Name Null? Type
------------------------------ -------- --------------------------------------------
OBJECT_ID NUMBER
SQL>
SQL> select * from test_visible where rownum < 3;
OBJECT_ID
----------
9
8

可以看到,當(dāng)column被修改為invisible(不可見)之后,你desc都無法查看該column的信息,當(dāng)然select查詢也不會返回該列的數(shù)據(jù)。

SQL> alter table test_visible modify (owner visible);
Table altered.
SQL> select * from test_visible where rownum < 3;
OBJECT_ID OWNER
---------- ----------
9 SYS
8 SYS
SQL> alter table test_visible modify (owner invisible);
Table altered.
SQL> select owner,table_name,column_name,HIDDEN_COLUMN,IDENTITY_COLUMN
2 from dba_tab_cols where owner='ROGER' and table_name='TEST_VISIBLE';
OWNER TABLE_NAME COLUMN_NAME HID IDE
---------- -------------------- -------------------- --- ---
ROGER TEST_VISIBLE OWNER YES NO
ROGER TEST_VISIBLE OBJECT_ID NO NO
SQL> insert into test_visible(objecT_id,owner) values(99999,'killdb.com');
1 row created.
SQL> commit;
Commit complete.
SQL> select * from test_visible;
OBJECT_ID
----------
9
8
7
6
5
4
3
2
99999
9 rows selected.
SQL>

當(dāng)column被設(shè)置為invisible 之后,不代表該列的數(shù)據(jù)就變化了,我們?nèi)匀豢梢赃M(jìn)行insert操作。

這里我比較好奇Oracle是在怎么來實(shí)現(xiàn)的,想想也應(yīng)該是通過修改數(shù)據(jù)字典col$的某個字典屬性來實(shí)現(xiàn),檢查發(fā)現(xiàn)果然是這樣的。

Oracle 12c 版本中col$ 數(shù)據(jù)字典表的結(jié)構(gòu)和column名稱的解釋如下:

create table col$ /* column table */
( obj# number not null, /* object number of base object */
col# number not null, /* column number as created */
segcol# number not null, /* column number in segment */
segcollength number not null, /* length of the segment column */
offset number not null, /* offset of column */
name varchar2("M_IDEN") not null, /* name of column */
type# number not null, /* data type of column */
/* for ADT column, type# = DTYADT */
length number not null, /* length of column in bytes */
fixedstorage number not null, /* flags: 0x01 = fixed, 0x02 = read-only */
precision# number, /* precision */
scale number, /* scale */
null$ number not null, /* 0 = NULLs permitted, */
/* > 0 = no NULLs permitted */
deflength number, /* default value expression text length */
default$ long, /* default value expression text */
/*
* If a table T(c1, addr, c2) contains an ADT column addr which is stored
* exploded, the table will be internally stored as
* T(c1, addr, C0003$, C0004$, C0005$, c2)
* Of these, only c1, addr and c2 are user visible columns. Thus, the
* user visible column numbers for (c1, addr, C0003$, C0004$, C0005$, c2)
* will be 1,2,0,0,0,3. And the corresponding internal column numbers will
* be 1,2,3,4,5,6.
*
* Some dictionary tables like icol$, ccol$ need to contain intcol# so
* that we can have indexes and constraints on ADT attributes. Also, these
* tables also need to contain col# to maintain backward compatibility.
* Most of these tables will need to be accessed by col#, intcol# so
* indexes are created on them based on (obj#, col#) and (obj#, intcol#).
* Indexes based on col# have to be non-unique if ADT attributes might
* appear in the table. Indexes based on intcol# can be unique.
*/
intcol# number not null, /* internal column number */
property number not null, /* column properties (bit flags): */
/* 0x0001 = 1 = ADT attribute column */
/* 0x0002 = 2 = OID column */
/* 0x0004 = 4 = nested table column */
/* 0x0008 = 8 = virtual column */
/* 0x0010 = 16 = nested table's SETID$ column */
/* 0x0020 = 32 = hidden column */
/* 0x0040 = 64 = primary-key based OID column */
/* 0x0080 = 128 = column is stored in a lob */
/* 0x0100 = 256 = system-generated column */
/* 0x0200 = 512 = rowinfo column of typed table/view */
/* 0x0400 = 1024 = nested table columns setid */
/* 0x0800 = 2048 = column not insertable */
/* 0x1000 = 4096 = column not updatable */
/* 0x2000 = 8192 = column not deletable */
/* 0x4000 = 16384 = dropped column */
/* 0x8000 = 32768 = unused column - data still in row */
/* 0x00010000 = 65536 = virtual column */
/* 0x00020000 = 131072 = place DESCEND operator on top */
/* 0x00040000 = 262144 = virtual column is NLS dependent */
/* 0x00080000 = 524288 = ref column (present as oid col) */
/* 0x00100000 = 1048576 = hidden snapshot base table column */
/* 0x00200000 = 2097152 = attribute column of a user-defined ref */
/* 0x00400000 = 4194304 = export hidden column,RLS on hidden col */
/* 0x00800000 = 8388608 = string column measured in characters */
/* 0x01000000 = 16777216 = virtual column expression specified */
/* 0x02000000 = 33554432 = typeid column */
/* 0x04000000 = 67108864 = Column is encrypted */
/* 0x20000000 = 536870912 = Column is encrypted without salt */
/* 0x000800000000 = 34359738368 = default with sequence */
/* 0x001000000000 = 68719476736 = default on null */
/* 0x002000000000 = 137438953472 = generated always identity column */
/* 0x004000000000 = 274877906944 = generated by default identity col */
/* 0x080000000000 = 8796093022208 = Column is sensitive */
/* The spares may be used as the column's NLS character set,
* the number of distinct column values, and the column's domain.
*/
/* the universal character set id maintained by NLS group */
charsetid number, /* NLS character set id */
/*
* charsetform
*/
charsetform number,
/* 1 = implicit: for CHAR, VARCHAR2, CLOB w/o a specified set */
/* 2 = nchar: for NCHAR, NCHAR VARYING, NCLOB */
/* 3 = explicit: for CHAR, etc. with "CHARACTER SET ..." clause */
/* 4 = flexible: for PL/SQL "flexible" parameters */
evaledition# number, /* evaluation edition */
unusablebefore# number, /* unusable before edition */
unusablebeginning# number, /* unusable beginning with edition */
spare1 number, /* fractional seconds precision */
spare2 number, /* interval leading field precision */
spare3 number, /* maximum number of characters in string */
spare4 varchar2(1000), /* NLS settings for this expression */
spare5 varchar2(1000),
spare6 date,
spare7 number,
spare8 number
)

大家注意看其中的 property 列的屬性,可以發(fā)現(xiàn)其中有hidden column的說明,這顯然就是invisible的意思。
下面我們可以通過查詢來觀察下其變化:

SQL> select owner,objecT_id from dba_objects where object_name='TEST_VISIBLE';
OWNER OBJECT_ID
---------- ----------
ROGER 91829
SQL> select obj#,col#,name,intcol#,property from col$ where obj#=91829;
OBJ# COL# NAME INTCOL# PROPERTY
---------- ---------- ------------------------------ ---------- -------------------
91829 0 OWNER 1 17179883552
91829 1 OBJECT_ID 2 14336
SQL> SELECT name, col#, intcol#, segcol#, TO_CHAR(property, 'XXXXXXXXXXXX')
2 FROM sys.col$
3 WHERE obj# = (SELECT obj# FROM sys.obj$ WHERE name = 'TEST_VISIBLE');
NAME COL# INTCOL# SEGCOL# TO_CHAR(PROPE
------------------------------ ---------- ---------- ---------- -------------
OWNER 0 1 1 400003820
OBJECT_ID 1 2 2 3800
SQL> alter table test_visible modify (owner VISIBLE);
Table altered.
SQL> SELECT name, col#, intcol#, segcol#, TO_CHAR(property, 'XXXXXXXXXXXX')
2 FROM sys.col$
3 WHERE obj# = (SELECT obj# FROM sys.obj$ WHERE name = 'TEST_VISIBLE');
NAME COL# INTCOL# SEGCOL# TO_CHAR(PROPE
------------------------------ ---------- ---------- ---------- -------------
OWNER 2 1 1 3800
OBJECT_ID 1 2 2 3800
SQL>

可以看到,我們的猜測是沒錯的,如果你通dbms_metadata去獲取table的定義,其實(shí)也能發(fā)現(xiàn)對于隱藏列Oracle加了一個invisible關(guān)鍵字:

SQL> select dbms_metadata.get_ddl('TABLE','TEST_VISIBLE') from dual;
DBMS_METADATA.GET_DDL('TABLE','TEST_VISIBLE')
--------------------------------------------------------------------------------
CREATE TABLE "ROGER"."TEST_VISIBLE"
( "OWNER" VARCHAR2(128) INVISIBLE,
"OBJECT_ID" NUMBER
) SEGMENT CREATION IMMEDIATE
PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255
NOCOMPRESS LOGGING
STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1
BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)
TABLESPACE "USERS"

后面有空還會繼續(xù)研究和分享Oracle 12c的其他內(nèi)容,這僅僅是個開始!

Related posts:

  1. about partiton column with date or varchar2?
  2. Oracle 12c學(xué)習(xí)系列之—identity column
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng): 轉(zhuǎn)載自love wife & love life —Roger 的Oracle技術(shù)博客 本文鏈接地址: Oracle 12c學(xué)習(xí)系列之—Row limits & Invisible Column Oracle 12c 引入了row limits的特性,玩Mysql的人都知道這個,然而Oracle卻一直沒有這個功能,不過在12c中終于實(shí)現(xiàn)了。 SQL> show con_name CON_NAME ------------------------------ PDBORCL SQL> create table test_lim as select * from dba_objects; Table created. SQL> select count(1) from test_lim; COUNT(1) ---------- 90929 SQL> col owner for a10 SQL> col objecT_name for a30 SQL> [...]

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Oracle12c學(xué)習(xí)系列之—Rowlimits&InvisibleColumn

Oracle12c學(xué)習(xí)系列之—Rowlimits&InvisibleColumn:本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng): 轉(zhuǎn)載自love wife love life —Roger 的Oracle技術(shù)博客 本文鏈接地址: Oracle 12c學(xué)習(xí)系列之—Row limits Invisible Column Oracle 12c 引入了row limits的特性,玩Mysql的人都知道這個,然而Ora
推薦度:
標(biāo)簽: 學(xué)習(xí) 系列 oracle
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top