我正在尝试在我的一个表中创建XML Type列上的XML索引。 我们在这里使用2个表空间,一个用于表,第二个用于索引。
我想在索引表空间中创建XMLIndex。
我使用以下查询 -
CREATE INDEX VISION_IX1 ON MDT_VISION_LOGGING_TBL(RAWMESSAGE)
INDEXTYPE IS XDB.XMLINDEX
NOPARALLEL;
请帮我提一下表空间条款。
答案 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