如何在Oracle 11g中为XML类型索引创建指定表空间

时间:2016-03-30 15:56:45

标签: xml oracle indexing oracle11g oracle-xml-db

我正在尝试在我的一个表中创建XML Type列上的XML索引。 我们在这里使用2个表空间,一个用于表,第二个用于索引。

我想在索引表空间中创建XMLIndex。

我使用以下查询 -

CREATE INDEX VISION_IX1 ON MDT_VISION_LOGGING_TBL(RAWMESSAGE)
INDEXTYPE IS XDB.XMLINDEX
NOPARALLEL;

请帮我提一下表空间条款。

1 个答案:

答案 0 :(得分:1)

您必须将路径表命名为能够指定存储for the unstructured component

CREATE TABLE MDT_VISION_LOGGING_TBL(ID NUMBER, RAWMESSAGE XMLTYPE) TABLESPACE TS_TABLES;

Table MDT_VISION_LOGGING_TBL created.

CREATE INDEX VISION_IX1 ON MDT_VISION_LOGGING_TBL(RAWMESSAGE)
INDEXTYPE IS XDB.XMLINDEX
PARAMETERS('PATH TABLE VISION_IX_PATH_TABLE (TABLESPACE TS_INDEXES)')
NOPARALLEL;

Index VISION_IX1 created.

您可以看到分配存储的位置:

SELECT US.SEGMENT_NAME, US.SEGMENT_TYPE, US.TABLESPACE_NAME
FROM USER_OBJECTS UO
JOIN USER_SEGMENTS US
ON US.SEGMENT_NAME = UO.OBJECT_NAME
WHERE UO.CREATED > TRUNC(SYSDATE);

SEGMENT_NAME                   SEGMENT_TYPE       TABLESPACE_NAME              
------------------------------ ------------------ ------------------------------
MDT_VISION_LOGGING_TBL         TABLE              TS_TABLES                         
SYS304166_VISION_IX_PIKEY_IX   INDEX              TS_TABLES                         
SYS304166_VISION_IX_VALUE_IX   INDEX              TS_TABLES                         
SYS_IL0000304163C00003$$       LOBINDEX           TS_TABLES                         
SYS_LOB0000304163C00003$$      LOBSEGMENT         TS_TABLES                         
VISION_IX_PATH_TABLE           TABLE              TS_INDEXES                        

您可以指定创建的其他两个索引也在您的首选表空间中:

CREATE INDEX VISION_IX1 ON MDT_VISION_LOGGING_TBL(RAWMESSAGE)
INDEXTYPE IS XDB.XMLINDEX
PARAMETERS('PATH TABLE VISION_IX_PATH_TABLE (TABLESPACE TS_TABLES)
  PIKEY INDEX VISION_IX_PIKEY (TABLESPACE TS_INDEXES)
  VALUE INDEX VISION_IX_VALUE (TABLESPACE TS_INDEXES)')
NOPARALLEL;

SELECT US.SEGMENT_NAME, US.SEGMENT_TYPE, US.TABLESPACE_NAME
FROM USER_OBJECTS UO
JOIN USER_SEGMENTS US
ON US.SEGMENT_NAME = UO.OBJECT_NAME
WHERE UO.CREATED > TRUNC(SYSDATE);

SEGMENT_NAME                   SEGMENT_TYPE       TABLESPACE_NAME              
------------------------------ ------------------ ------------------------------
MDT_VISION_LOGGING_TBL         TABLE              TS_TABLES                         
SYS_IL0000304183C00003$$       LOBINDEX           TS_TABLES                         
SYS_LOB0000304183C00003$$      LOBSEGMENT         TS_TABLES                         
VISION_IX_PATH_TABLE           TABLE              TS_INDEXES                        
VISION_IX_PIKEY                INDEX              TS_INDEXES                        
VISION_IX_VALUE                INDEX              TS_INDEXES