21.05.2011 08:27
AlexeyF
 
Oracle10
У меня у большей части баз существует отдельное табличное пространство INDEX, соответственно под индексы и USERS под данные. Обнаружил что у одной базы только USERS. Надо теперь в этой базе вынести индексы в отдельное табличное пространство.

Знаю про Alter index <index-name> rebuild tablespace <new-tablespace>

Есть скрипт:
SET PAGESIZE 0
SET SERVEROUTPUT ON SIZE 1000000
SET FEEDBACK OFF
SPOOL rebuild.scr

SELECT 'alter index '|| i.index_name || ' rebuild online;'
FROM user_indexes i;

SPOOL OFF
SPOOL rebuild.lst
@rebuild.scr
SPOOL OFF
EXIT


могу посмотреть в каком табличном конкретный индекс лежит.

Два вопроса не могу найти теперь.
Есть или нет у оракла параметр на тему хранить все индексы там то ?
Или хранить все индексы таблиц пространства, например USERS, там то ?
21.05.2011 09:33
Mtirt
 
Параметра нет.
Можно создать табличное пространство и прогнать генератор баз данных Супермага, поставив галочку - переместить индексы.
Часовой пояс GMT +3, время: 07:12.

Форум на базе vBulletin®
Copyright © Jelsoft Enterprises Ltd.
В случае заимствования информации гипертекстовая индексируемая ссылка на Форум обязательна.