Oracle добавить файл в tablespace
Платформа 1С:Предприятие 8.2 при работе с СУБД Oracle Database создает следующие табличные пространства:
- V81C_DaTa - для данных,
- V81C_INDEX - для индексов,
- V81C_LOB - для строк неограниченной длины и объектов ХранилищеЗначений,
- V81C_TEMP - для временных данных.
Табличные пространства создаются при создании информационной базы данных лишь в том случае, если их не существует. Это означает, что при создании первой информационной базы с использованием СУБД Oracle Database табличные пространства будут созданы, а все последующие информационные базы будут использовать эти табличные пространства.
Создаваемые табличные пространства содержат один файл данных (datafile в терминологии Oracle Database). Ввиду того, что создаваемое табличное пространство является обычным (без опции bigfile), файлы данных ограничены размером в 32ГБ (данное значение подразумевает использование блока величиной 8КБ - значение по умолчанию ).
Отличие обычного табличного пространства от табличного пространства BIGFILE описано в таблице.
Может состоять из множества файлов данных.
Состоит из одного файла данных.
Каждый файл данных ограничен 32ГБ (по умолчанию).
Размер файла данных ограничен 32ТБ (по умолчанию).
Есть возможность использовать несколько дисков для одного табличного пространства.
Один файл подразумевает использование одного логического диска, а значит, не допускает распределения на несколько дисков.
Когда заполнение файла данных достигает 85% ( значение по умолчанию ), СУБД Oracle Database генерирует предупреждение в alert log. В это время необходимо добавить файл данных к табличному пространству. Если действия не предприняты, то при заполнении файла данных на 97% (значение по умолчанию) генерируется ошибка о том, что СУБД не смогла выделить следующий сегмент данных.
Типичный сценарий использования СУБД Oracle Database подразумевает, что администратор следит за состоянием alert log и предпринимает действия, необходимые для того, чтобы избежать простоя в работе информационной системы. Для того чтобы добавить файл данных в табличное пространство, необходимо исполнить команду.
SQL> aLTER TaBLESPaCE V81C_DaTa aDD DaTaFILE 'C:\ORaCLE\PRODUCT\10.2.0\ORa1C\V81C_DaTa2.DBF' SIZE 40M aUTOEXTEND ON NEXT 10M;
Существует способ создать табличное пространство с опцией bigfile, но следует помнить, что тогда администратор теряет контроль над распределением места для файлов данных Oracle Database (табличное пространство с опцией bigfile может состоять только из одного файла). Для создания табличного пространства с опцией bigfile необходимо исполнить команду.
SQL> CREaTE BIGFILE TaBLESPaCE V81C_LOB DaTaFILE 'C:\ORaCLE\PRODUCT\10.2.0\ORa1C\V81C_LOB.dbf' SIZE 64G;
Следует иметь в виду данные обстоятельства при загрузке больших информационных баз. Если загружаемая информационная база занимает пространства больше, чем 32ГБ, то стоит позаботиться о расширении табличных пространств заранее, до загрузки информационной базы. Создав табличное пространство с опцией BIGFILE до загрузки информационной базы, ограничение в 32ГБ будет сдвинуто до следующего предела - 32 ТБ (терабайта).
Другие материалы по теме:
Нас находят: Создаете три tablespace V81C_DATA V81C_INDEX V81C_LOB, v81c_data, ora-32771, ORA-32771: невозможно добавить файл в табличное пространство bigfile, строка подключения из 1с 8 2 к sql oracle, создание табличных пространств bigfile, создание bigfile tablespace, работа с файоами oracle, работа с файлами oracle, при заполнении datafile oracle
В этом учебном пособии вы узнаете, как использовать Oracle оператор ALTER TABLESPACE с синтаксисом и примерами.
Описание
Оператор ALTER TABLESPACE используется для изменения табличного пространства или одного из его файлов данных или временных файлов. Табличное пространство используется для выделения пространства в базе данных Oracle, где хранятся объекты схемы.
Синтаксис
Синтаксис для оператора ALTER TABLESPACE в Oracle / PLSQL:
ALTER TABLESPACE tablespace_name< DEFAULT
[ < COMPRESS | NOCOMPRESS >] storage_clause
| MINIMUM EXTENT integer [ K | M | G | T | P | E ]
| RESIZE integer [ K | M | G | T | P | E ]
| COALESCE
| RENAME TO new_tablespace_name
| < BEGIN | END >BACKUP
| < ADD < DATAFILE | TEMPFILE >
[ file_specification
[, file_specification ]
]
| DROP < 'filename' | file_number >
| RENAME DATAFILE 'filename' [, 'filename' ] TO 'filename' [, 'filename' ]
| < DATAFILE | TEMPFILE >< ONLINE | OFFLINE >
>
| < logging_clause | [ NO ] FORCE LOGGING >
| TABLESPACE GROUP < tablespace_group_name | '' >
| < ONLINE
| OFFLINE [ NORMAL | TEMPORARY | IMMEDIATE ]
>
| READ < ONLY | WRITE >
| < PERMANENT | TEMPORARY >
| AUTOEXTEND
< OFF
| ON [ NEXT integer [ K | M | G | T | P | E ] ]
[ MAXSIZE < UNLIMITED | integer [ K | M | G | T | P | E ] >]
>
| FLASHBACK < ON | OFF >
| RETENTION < GUARANTEE | NOGUARANTEE >
> ;
Параметры или аргументы
tablespace_name - имя табличного пространства для удаления из базы данных Oracle.
storage_clause - синтаксис для файла storage_clause:
( < INITIAL integer [ K | M | G | T | P | E ]
| NEXT integer [ K | M | G | T | P | E ]
| MINEXTENTS integer
| MAXEXTENTS < integer | UNLIMITED >
| PCTINCREASE integer
| FREELISTS integer
| FREELIST GROUPS integer
| OPTIMAL [ integer [ K | M | G | T | P | E ] | NULL ]
| BUFFER_POOL < KEEP | RECYCLE | DEFAULT >
>
[ INITIAL integer [ K | M | G | T | P | E ]
| NEXT integer [ K | M | G | T | P | E ]
| MINEXTENTS integer
| MAXEXTENTS < integer | UNLIMITED >
| PCTINCREASE integer
| FREELISTS integer
| FREELIST GROUPS integer
| OPTIMAL [ integer [ K | M | G | T | P | E ] | NULL ]
| BUFFER_POOL < KEEP | RECYCLE | DEFAULT >
]
)
file_specification - синтаксис для параметра file_specification:
< [ 'filename' | 'ASM_filename' ]
[ SIZE integer [ K | M | G | T | P | E ] ]
[ REUSE ]
[ AUTOEXTEND
< OFF
| ON [ NEXT integer [ K | M | G | T | P | E ] ]
[ MAXSIZE < UNLIMITED | integer [ K | M | G | T | P | E ] >]
>
]
| [ 'filename | ASM_filename'
| ('filename | ASM_filename'
[, 'filename | ASM_filename' ] )
]
[ SIZE integer [ K | M | G | T | P | E ] ]
[ REUSE ]
>
Пример. Переименование файла данных.
Рассмотрим оператор ALTER TABLESPACE, который переименовывает файл данных, связанный с табличным пространством.
В прошлый раз мы с вами создали пару табличных пространств, и поработали с ними. Кое, что надеюсь, стало уже яснее, а кое что может еще потребовать рассмотрения. Если вы оставили табличные пространства из прошлого шага, то можете работать с ними, если нет, то давайте проделаем следующее. Посмотрим как можно, создав табличное пространство, добавить к нему файл данных, а затем рассмотрим что из этого вытекает! Итак, запускаем SQL*Plus и заходим в ваш экземпляр с правами DBA пользователем SYS или SYSTEM, (можете и MILLER'ом, если ваш админ дал вам права на создание табличных пространств) затем запускаем такой SQL код: (если хотите, можете использовать табличное пространство из прошлого шага):
Видим после прохода:
Мы создали табличное пространство PROBATBS величиной 100M и возможностью расширения до 200M. А что если вам по какой-либо причине, скажем, почти полной загрузке этого пространства, добавить еще один раздел! Запустим вот такой скрипт:
Видим после прохода:
Теперь к вашему табличному пространству PROBATBS добавлен еще один кусочек пространства в виде файла данных PRBTWO.DAT. Который может расширяться до 100M, что в совокупности составит 300M табличного пространства PROBATBS. Для большей убедительности давайте дадим запрос к системному представлению:
Хорошо видно, что мы получили одно табличное пространство PROBATBS состоящее из двух(!) файлов данных. Вот таким образом можно строить и вводить в работу табличные пространства, которые будут вам необходимы в дальнейшем.
И вот здесь мы подходим к тематике, которая напрашивается сама собой. Все табличные пространства это не что иное, как файлы данных на жестких дисках ваших серверов! Так? Значит здесь необходимо продумывать такой вопрос, как настройка всей системы в целом для достижения наибольшей производительности системы. Сама по себе настройка системы ввода-вывода заключается в основном в настройке физической структуры сегментов (таблиц и индексов), которые образуют базу данных. Настройка охватывает табличные пространства состоящие из экстентов, которые в свою очередь состоят из блоков и файлов данных. Все это представляет из себя, в конечном счете, объекты операционной системы! Операции ввода-вывода представляют из себя не что иное, как операции чтения и записи. А вернее это DML - операции такие как SELECT, INSERT, UPDATE, DELETE. Где SELECT - это операция чтения, а UPDATE, INSERT, DELETE - это операции записи! Так!? И DDL - операции это тоже операции записи! Таким образом, любые операции ввода-вывода требуют настройки не только табличных пространств, экстентов, блоков и файлов данных, но также сегментов отката и журналов регистрации транзакций. В связи с тем, что DML - операции пользователей затрагивают все эти объекты.
Думаю, все помнят, я не говорил, что все будет просто! Oracle достаточно сложная СУБД, но и в тоже время простая и надежная БД! Далее попробуем во всем этом разобраться! :)
Когда ваше табличное пространство заполняется данными таблиц или индексов, необходимо увеличить его размер. Это делается добавлением файлов в команде ALTER TABLESPACE:
Можно также увеличивать или уменьшать размер табличного пространства, увеличивая или уменьшая размер файлов данных табличного пространства опцией RESIZE.Обычно опция RESIZE применяется для исправления ошибок, допущенных при задании размера файла данных. Обратите внимание, что размер файла данных нельзя сделать меньше того, что уже занят объектами, хранящимися в нем.
Следующий пример показывает, как изменить размер файла данных вручную.Изначально файл имеет размер 250 Мбайт, а следующая команда удваивает его размер до 500 Мбайт. Заметьте, что для изменения размера файла данных необходимо использовать команду ALTER DATABASE, а не ALTER TABLESPACE.
При создании табличного пространства или при добавлении к табличному пространству файлов данных можно указывать конструкцию AUTOEXTEND, чтобы заставить Oracle автоматически расширять размер файлов данных в табличном пространстве до заданного максимума.
Вот как выглядит синтаксис использования средства AUTOEXTEND:
В предыдущем примере экстенты в 10 Мбайт будут добавляться к табличному пространству, когда понадобится дополнительное место, как указано в параметре AUTOEXTEND. Параметр MAXSIZE ограничивает табличное пространство размером в 1000 Мбайт. При желании можно также специфицировать MAXSIZE UNLIMITED; в этом случае не устанавливается максимальный размер данного файла данных, а следовательно и всего табличного пространства. Однако необходимо убедиться в наличии достаточного пространства на диске операционной системы.
Oracle также предоставляет средство Resumable Space Allocation, временно приостанавливающее операции, которые могут в противном случае завершиться сбоем из-за нехватки места, а затем возобновляет их выполнение после того, как вы добавите место для объекта базы данных. Это делает использование средства AUTOEXTEND менее привлекательным.
Табличные пространства это хранилище для данных схемы, включая словарь данных (который находится в схеме SYS). У всех баз данных обязаны быть табличные пространства SYSTEM и SYSAUX и (для работы с БД) временное табличное пространство и пространство undo. Обычно эти четыре табличных пространства создаются на этапе создания БД. В дальнейшем DBA может создавать много других табличных пространств для пользовательских данных, и возможно дополнительные пространства для undo и временных данных.
Создание табличного пространства
Для создания табличного пространства с помощью Enterpise Manager Database Control с домашней страницы базы данных перейдите на вкладку Server и нажмите на ссылку Tablespaces в разделе Storage. На рисунке 5-3 отображается результат для БД по умолчанию.
Рисунок 5-3 – Табличные пространства в БД ocp11g
Для каждого табличного пространства отображаются:
- Allocatedsize –размер файла/ов данных табличного пространства. Это текущее значение, а не максимальное до которого может быть расширено
- Spaceused – это пространство использованное сегментами
- Allocatedspaceused (%) – графическое представление предыдущих значений
- Allocatedfreespace – пространство доступное на данный момент в табличном пространстве
- Status – зелёная галочка отображает что табличное пространтсво в рабочем состоянии и объекты этого пространства доступны для использования. Выключенное табличное пространство (offline) будут отображаться как красный крестик
- Datafiles – колчиество файлов данных (или временных файлов для временного табличного пространства) которые входят в табличное пространство
- Type – типы объектов, которые могут храниться в этом табличном пространстве. Постоянные пространства (permanent) могут хранить обычные объекты схемы, такие как таблицы и индексы. Временные табличные пространства могут хранить управляемые системой временные а сегменты, а пространства undo только системно управляемые сегменты undo
- Extentmanagement – метод выделения экстентов для сегмента. LOCAL значение по умолчанию и всегда должно использоваться
- Segmentmanagement – метод выделения блоков доступных для вставки данных. AUTO значение по умолчанию и рекомендуется для всех табличных пространств содержащих пользовательские данные.
Эту же информацию можно получить написав запрос к предсатвлениям словаря данных DBA_TABLESPACES, DBA_DATA_FILES, DBA_SEGMENTS и DB_FREE_SPACE. К примеру результатом выполнения запроса
t.status, d.cnt, contents, t.extent_management extman,
from dba_tablespaces t,
(select sum(bytes) allocated, count(file_id) cnt from dba_data_files
(select sum(bytes) free from dba_free_space
(select sum(bytes) used from dba_segments
На этой же странице нажмите кнопку CREATE для создания нового табличного пространства. Новое окно создания запросит название нового табличного пространства, значения для Extent Management, Type и Status. В большинстве случаев значения по умолчанию валидны: Local, Permanent и Read Write. Затем кнопка ADD позволяет указать один или более файлов данных для нового табличного пространства. Для каждого файла необходимо указать имя файла и размер, также опционально можно включить autoextend до максимального допустимого размера файла. Возможность autoxtend позволяет Oracle серверу самому увеличиваться размер файлов данных при необходимости, что позволит избежать ошибок из-за нехватки места. На рисунках 5-4 и 5-5 отображены окна Database Control для создания табличного пространства NEWTS с одним файлом данных.
Рисунок 5-4 Окно создания табличного пространства Рисунок 5-5 Окно добавления файла данных
Нажав кнопку CONTINUE вы вернётесь к окну создания табличного пространства. Нажатие кнопки SHOW SQL отобразит сгенерированный запрос
Рассмотрим эту команду построчно
3 SIZE 100M AUTOEXTEND ON NEXT 100K MAXSIZE 200M – Файл данных будет создан размеров 100 Мб, при заполнении будет автоматически выделяться 100Кб до максимально допустимого значения в 200 Мб. По умолчанию автоматическое выделения места не включено.
4 LOGGING – Все операции над сегментами в табличном пространстве будут генерировать данные для повтора изменений (redo): это значение по умолчанию. Возможно отключить генерацию redo только для нескольких операция (таких как создание индекса)
5 EXTENT MANAGEMENT LOCAL – табличное пространство будет использовать битовые карты для выделения экстентов; значение по умолчанию
6 SEGMENT SPACE MANAGEMENT AUTO – Сегменты в табличном пространстве будут использовать битовые карты для отслеживания использования блоков; значение по умолчанию
Если выбрать вкладку Storage в окне создания табличного пространства то можно управлять параметрами управления экстентами и сжатия – Рисунок 5-6.
Рисунок 5-6 Дополнительные параметры создания табличного пространства
Когда используется локальное управление экстентами, возможно включить функционал согласно которому все экстенты в табличном пространстве будут одного размера. Также доступны опции сжатия, логирования.
Пример команды создания табличного пространства выполненной в SQL* Plus показан на рисунке 5-7.
Табличное пространство STORETABS состоит из двух файлов данных, оба без автоинкремента. Единственное различие от команды по умолчанию это указание размера extent-а в 5 МБ. Первый запрос на рисунке показывает что файлы не большие иначе нельзя было бы создать два файла данных. Второй запрос на рисунке отображает информацию о табличном пространстве TEMP, используемом для хранения временных объектов. Важно понимать что временное табличное пространство использует временные файлы, а не файлы данных. Временные файлы перечислены в пресдатвлении V$TEMPFILE и DBA_TEMP_FILES, когда файлы данных перечислены в V$DATAFILE и DBA_DATA_FILES. Также важно отметить что V$ и DBA показывают разную информацию. В V$TABLESPACE находится информация является ли табличное пространтсво «большим» и в V$TEMPFILE (или V$DATAFILE) размер файлов. Этой информации нет в представлениях DBA. Но представления DBA содержат детальную информацию о экстентах и сегментах. Разная информация доступна либо там либо там, так как некоторая информация хранится в файле контроле (и доступна только в V$ представлениях), а другая хранится в словаре данных (и видима в DBA представлениях). Остальная информация дублируется.
Изменение табличных пространств
Изменения происходящие над табличным пространством после создания обычно
- Переименование
- Включение выключение (online/offline)
- Переключение в режим только-чтение и обратно
- Изменение размера
- Изменение уровня препупреждений
Переименование табличного пространтсва и его файлов
ALTER TABLESPACE tablespaceoldname RENAME TO tablespacenewname;
Первая команда изменяет имя табличного пространства. Это самая легкая часть. Затем табличное пространство выключается, и выполняются команды операционной среды переименовать файлы. Затем две команды ALTER DATABASE изменяют имена файлов в файле контроля, и Oracle сможет их найти. И наконец табличное пространство включается.
Включение и выключение табличного пространтсва (Online/Offline)
Включенным табличным пространством является пространство готовое к использованию; выключенное табличное пространство определено в словаре данны и файле контроля, но его нельзя использовать. Табличное пространтсво может быть включенным, но один или несколько файлов данных внутри него могут быть выключены. Такая ситуация может привести к неожиданным результатам и следует избегать её возникновения.
Синтаксис для выключения табличного пространства
ALTER TABLESPACE tablespacename OFFLINE [NORMAL|IMMEDIATE|TEMPORARY]
Обычное выключение (NORMAL – значение по умолчанию) запустит создание контрольной точки для всех файлов данных этого пространства. Все грязные буфферы в кэше которые содержат блоки из табличного пространтсва будут записаны в файлы данных и табличное пространство и файлы данных будут выключены.
Режим IMMEDIATE выключает табличное пространтсво и файлы данных сразу, без очищения буфера. Это значит что файлы данных станут повреждёнными (не содержат подтверждённые изменения) и необходимо будет восстанавливать их состояние (путём чтения и применения лога изменений) перед тем как можно будет их включить. Этот режим стоит использовать только если файлы были повреждены и контрольная точка не может быть создана.
Режим TEMPORARY создаст контрольную точку для всех файлов для которых она может быть создана и затем по порядку выключит файлы и табличное пространство. Любые повреждённые файлы будут выключены сразу. Если только один некоторые файлы были повреждёны, этот режим поможет ограничить количество файлов которые надо восстанавливать.
Режим только-чтения (Read only)
Чтобы понять эффект режима только чтения изучите рисунок 5-9. Синтаксис команды говорит сам за себя
ALTER TABLESPACE tablespacename [READONLY|READ WRITE];
После перевода в режим только-чтения, объекты не могут быть созданы используя DML команды. Но они могут быть удалены. Выглядит нелогично но давайте подумаем. Удаление таблицы на самом деле не выполняет каких-либо действий над таблицей. Это транзакция над словарём данных, которая удаляет строки описывающие таблицу и её столбцы; словарь данных находится в табличном пространстве SYSTEM и оно не только для чтения. Создание таблицы в пространстве находящемся в режиме только для чтения также будет неуспешно, так как кроме DDL запроса должно выделиться физическое место для первого экстента таблицы (если не включен deferred segment creation. Если включен то место не будет выделяться и запрос выполниться успешно, однако при попытке добавить строки в созданную таблицу будет ошибка).
Изменение размера табличного пространста
Размер табличного пространства может быть изменён как добавлением файлов данных в него так и изменением размера существующих файлов. Файлы данных могут быть увеличены автоматически при необходимости если была указана опция AUTOEXTEND при создании. Иначе вам придётся делать это вручную используя команду ALTER DATABASE
ALTER DATABASE DATAFILE filename RESIZE n [M|G|T]
M G и T это мегабайт, гигабайт и терабайт соответсвенно.
alter dtabase datafile ‘/oradata/users_02.dbf’resize 10m;
Из команды вы не знаете станет ли файл больше или меньше. Размер может быть увеличен только если в файловой системе достаточно свободного места. Уменьшение размера возможно только если внутри файла сущесвует достаточно места не выделенного под сегменты.
Изменение уровня предупреждений
Чтобы посмотреть или изменить эти значения в Database Control можно выбрать Tablespace на вкладкe Server и нажать EDIT. Затем в окне управления пространством перейти на вкладку Thresholds. На рисунке 5-10 показан пример для пространства EXAMPLE.
Рисунок 5-10 Окно управления предупреждениями
На этом рисунке “Available Space” указано как 32Гб. Что полностью неверно, так как выделенное место как видно на рисунке 5-3 всего 100МБ. Это происходит так как включен AUTOEXTENSION. Если AUTOEXTEND указан для файла и не установленм MAXSIZE, тогда файл может увеличиваться до платформо-зависимого ограничения, в нашем случае 32 ГБ. Конечно это не значит что у системы есть место для таких файлов. Система предупреждения рассчитыает лимиты и использует максимально допустимый размер файла как основу для вычисления, и это абсолютно быссмесленно если у вас включен AUTOEXTEND и не указан MAXSIZE.
Становится понятно что при использовании автоматического управления размером желательно указывать максимальное значение. Это можно сделать и Database Control или командой ALTER DATABASE.
Удаление табличных пространств
Для удаления табличного пространтсва используется команда
DROP TABLESPACE tablespacename [INCLUDING CONTENTS [AND DATAFILES]];
Если не указано INCLUDING CONTENS то удаление не выполнится если существуют объекты в табличном пространстве. Используя этот параметр вы указываете Oracle вначале удалить все объекты, а затем удалить табличное пространство. И даже эта команда может быть выполнена неуспешно если например в табличном пространстве создана таблица родитель для внешнего ключа таблицы созданной в другом табличном пространстве.
Если не указано AND DATAFILES тогда табличное пространство и его содержимое будет удалено однако файлы данных не будут удалены с диска. Oracle не будет знать ничего об этих файлах после удаления табличного пространства и файлы можно будет удалить только командами операционной системы.
Oracle Managed Files (OMF)
Использование OMF должно избавить DBA от необходимости знать что-либо о файловой системе. Создание файлов БД может быть полностью автоматическим. Для включения OMF необходимо установить параметры экземпляра
Параметр DB_CREATE_FILE_DEST определяет путь по умолчанию дял файлов данных. Параметры DB_CREATE_ONLINE_LOG_DEST_n указывают путь файла текщих логов. Параметр DB_RECOVERY_FILE_DEST определяет путь к файлам архивных логовов и резервных копий. OMF будет использовать эти пути и создавать файлы со сгенерированными именами и (по умолчанию) устанавливать размер файлов. При включенном OMF всё равно можно указать имя вручную при создании табличного пространства.
Читайте также: