Создать директорию в oracle
Есть значит сторонняя программа (экспорт из этой программы формирование всех документов их много) формируется txt фаил в нём данные расположены блоками типа.
Начало файла
(информация о файле)
.
Начало документа
(информация о документе)
.
Конец документа
(следующий файл)
.
Конец файла
Можно ли сделать так чтобы из этого самого файла ну скажем каждый день в 00 часов 00 минут делалась выборка и заносилась в БД (формировались таблицы, делался апдейт ячеек)? Я пока не спрашиваю как это сделать, но этот вопрос меня тоже интересует для начала хочу узнать возможно ли это вообще?
__________________Помощь в написании контрольных, курсовых и дипломных работ здесь
Чтение из внешнего файла.
Надо составить матрицу размерностью NxN, и записать во внешний файл. Потом прочитать сначала.
Чтение внешнего файла программой (.dat/.asm)
Вот есть код , он создает файл и открывает этот файл без проблем, но если файл попробовать открыть.
Чтение заголовка из внешнего файла формата TGA grayscale (TGAgs)
Подскажите как можно считать заголовок из внешнего файла формата TGA grayscale (TGAgs или Targa.
))))) Я хотел услышать ответ да выборка информации из внешнего файла возможна.
А не просто слово возможно )))
Добавлено через 2 минуты
Но хоть и на этом спасибо я сам недельку попробую потом результаты и с вопросом сюда обращусь.
Чего-то я не понял совсем куда чего как!?
Я значит нажимаю на белый листик выбираю там Командное окно или SQL окно Вставляю туда текст
Предварительно создав на диске С папку и файл внутри этой папки.
Я правильно понимаю что в файле должно появится три строчки с надписями.
This is the first line
This is the second line
This is the third line
Что я не так понял?
Добавлено через 36 секунд
Может я не туда код на выполнение вставляю?
Добавлено через 43 минуты
Нашел ещё
где ошибка.
1СОздал папку
2Создал text
3Открыл Оракле
4Куда код вставлять незнаю
5А то что сервер это не мой комп важно!?
Что я в базу захожу через сервер который стоит в другой комнате. Весьма. Код исполняется на сервере. Сервер работает ТОЛЬКО с директориями, расположенными на сервере.
Работать с клиентскими директориями - дело клиентских приложений, а не сервера БД. Не царское это дело А какой тег то использовать? Я не нашел тега "оракле" как он обозначается ?
P.S. Это значит что я пару папок и файлов на сервера создал? +)))) Это значит что я пару папок и файлов на сервера создал? CREATE DIRECTORY не создает реальный директорий в файловой системе. Он создает только объект Oracle для отслеживания прав доступа. Поэтому если ты в файловой системе сервера не создал директорий, то и файл не должен был создаться - должно вернуть ошибку. Да уж жуть какая уже очень долго ищу способ как это сделать. =(
Ещё раз опишу суть проблемы.
Есть сервер с оракле, есть подключённый к нему комп на компе есть файл в котором данные которые надо занести в БД как с этого компа это сделать?
Открыть файл считать данные в БД\записать другие данные в файл.
Есть ли вообще такой способ.
utl_file предназначен для работы (чтения и записи) с файлами, которые находятся на сервере. Если ты не можешь закинуть файл на сервер (и не можешь попросить об этом админа), то это тебе не подходит.
Если у тебя файл регулярной структуры (например, в формате csv), то можно воспользоваться утилитой SQL*Loader, которая входит в состав клиента (вроде только в административную установку). Почитать про нее можно в томе доки Utilites.
Если и это условие не выполняется, то единственный способ - писать собственную программу на каком-нибудь языке (на том же Delphi) для загрузки такого файла.
Да в общем-то не искал не нашел способ. Запилил как и предполагалось программу которая каждый день в одно и тоже время кидает файл на сервер врубает процедуру в оракле капец как неудобно всё из-за того что мне не дали на сервере с админскими настройками разобраться там просто надо прошарить комп для сервера как разрешенный и зарегистрировать его тогда оракле начинает видеть сетевые компы и диски на них я дома попробовал +))))))Извлечение данных из внешнего файла
Добрый вечер. У меня есть файл с данными. Пример одной строки: 1 214 5152 15215 1251.
Сортировке данных из внешнего файла
Здравствуйте. Есть 2 файла данных, в одном 40, в другом 25 значений. Требуется отсекать.
Чтение файла, чтение названия папки где находится файл, запись данных на PHP
Допустим у нас есть структура с папками типа Large -> Vehicles -> Firetruck_0 В этой папке лежит.
Импорт данных из внешнего источника, файла
Всем привет! Задумался тут на чем лучше, практичнее и работоспособнее организовывать импорт.
Создайте объект DIRECTORY , соответствующий каталогу в файловой системе, где находится внешний источник данных.
Для создания объекта каталога для внешней таблицы используйте инструкцию CREATE DIRECTORY . Объект каталога задает псевдоним каталога в файловой системе сервера, где находится внешний источник данных. При ссылке на внешний источник данных можно использовать имена каталогов вместо жестко заданного в программе имени пути операционной системы с целью обеспечения большей гибкости управления файлами.
Для создания каталогов необходимо иметь системные привилегии CREATE ANY DIRECTORY . При создании каталога пользователю автоматически предоставляются объектные привилегии, и он может выдать привилегии READ и WRITE другим пользователям и ролям. Администратор базы данных также может предоставить эти привилегии другим пользователям и ролям.
Пользователю требуются привилегии READ на все каталоги, используемые во внешних таблицах, к которым происходит обращение, и привилегии WRITE для задействованных местоположений журнала, плохих и отвергнутых файлов.
Кроме того, привилегия WRITE необходима в случае, когда для выгрузки данных используется структура внешней таблицы.
Oracle предоставляет также тип ORACLE_DATAPUMP , с помощью которого можно выгрузить данные (т. е. прочитать данные из таблицы в базу данных и вставить их во внешнюю таблицу) и затем повторно загрузить их в базу данных Oracle. Это одноразовая операция, которая может быть выполнена при создании таблицы. После того как выполнено создание и заполнение начальными данными, какие либо строки невозможно обновить, вставить или удалить.
CREATE [ OR REPLACE ] DIRECTORY AS 'path_name';
OR REPLACE Укажите предложение OR REPLACE , чтобы повторно создать объект каталога базы данных, если он уже существует. Это предложение позволяет изменить определение существующего каталога без удаления, повторного создания и повторного предоставления объектных привилегий базы данных, которые были выданы ранее на каталог. Пользователи, получившие ранее привилегии на переопределенный каталог, могут продолжать обращаться к каталогу без необходимости повторного предоставления им привилегий.
directory Указывается имя создаваемого объекта каталога. Максимальная длина имени каталога равна 30 байтам. Объект каталога невозможно определить с помощью имени схемы.
'path_name' Указывается имя полного пути к каталогу операционной системы, к которому происходит обращение. Имя пути зависит от регистра.
В состав технологии Data Pump входят утилиты: Data Pump Export (expdp) и Data Pump Import (impdp).
Data Pump Export – выгружает данные в файлы операционной системы, называемые файлами дампа (dumps files), в специальном формате, который может понимать только утилита Data Pump Import.
Получить справку по утилитам можно выполнив команды:
Если необходимо выполнить экспорт схемы или ее объектов, воспользуйтесь правами данной схемы. Использовать полномочия учетных записей sys и system не рекомендуется (по той причине, что для импорта могут потребоваться права sys и system соотвестственно).
Файл параметров экспорта схемы.
JOB_NAME - имя задания, чтобы при необходимости задание можно было бы идентифицировать по имени.
DUMPFILE - каталог для дампа LOGFILE - каталог для логов
dplogs - ссылка в базе данных на каталог в котором должны будут сохраниться логи результата выполнения экспорта схемы базы данных.
dpdumps - ссылка в базе данных на каталог в котором должны будут сохраниться файл дампа базы данных.
dplogs и dpdumps должны ссылаться на реальные каталоги операционной системы с достаточным набором прав на запись.
Создание ссылки в базе данных на катлоги операционной системы
Посмотреть уже имеющиеся каталоги для datapump:
Мне не нравится каталог по умолчанию. Предпочитаю его удалить
Делегирую права на запись в данную директорию пользователю scott
Если необходимо предоставить возможность экспорта данных в указанные каталоги для любых схем:
Экспорт схемы с использованием файла параметров:
В некоторых случаях необходимо явно указать SID базы данных.
Экспорт можно выполнить одной командой без использования файла параметров:
Технология Data Pump состоит из трех главных компонентов:
- Пакет DBMS_DATAPUMP – это главный механизм для осуществления загрузки и выгрузки метаданных словаря данных. В пакете DBMS_DATAPUMP содержится основополагающие элементы технологии Data Pump в виде процедур, которые в действиельности приводят в действие задания по загрузке и выгрузке данных. Содержимое этого пакета отвечает за работу как утилиты Data Pump export, так и утилиты Data Pump Import.
- Пакет DBMS_METADATA – для извлечения и изменения метаданных Oracle.
- Клиенты с интерфейсом командной строки – impdbp и expdp
Режимы утилиты Data Pump Export
Data Pump Export поддерживает несколько режимов для выполнения заданий.
- Режим экспорта всей базы данных. Позволяет выполнять экспорт всей базы данных за один сеанс экспорта с помощью параметра FULL. Для использования этого режима, необходимы привилегии EXPORT_FULL_DATABASE.
- Режим схем. Позволяет выполнять экспорт данных и/или объектов только конкретного пользователя с помощью параметра SCHEMAS.
- Режим табличных пространств. Позволяет выполнять экспорт всех таблиц, которые содержатся в одном или нескольких табливчных пространствах, с помощью параметра TABLESPACES или только метаданных тех объектов, которые содержатся в одном или нескольких табличных пространствах, с помощью параметра TRANSPORT_TABLESPACES. Выполнять экспорт табличных пространств между базами данных можно, чначала выполнив экспорт метаданных, затем скопировав файлы табличного пространства на целевой сервер, а потом импортировав метаданные в целевую базу данных.
- Режим таблиц. Позволяет выполнять экспорт только одной или нескольких конкретных таблиц с помощью параметра TABLES.
По умолчанию для выполнения заданий Data Pump Export и Data Pump Import используется режим схем.
Параметры фильтрации экспортируемых данных.
Параметр CONTENT - позволяет выполнять фильтрацию тех данных, которые должны помещаться в файл дампа при экспорте. Он может принимать следующие значения:
- ALL – указывает, что требуется экспортировать как данные таблиц, так и определения этих таблиц и других объектов (метаданных);
- DATA_ONLY – указывает, что требуется экспортировать только строки таблиц.
- METADATA_ONLY – указывает, что требуется экспортировать только метаданные.
Парамтеры ECLUDE и INCLUDE
Параметры EXCLUDE и INCLUDE – это два взаимоисключающих параметра, которые можно применять для выполнения так называемой фильтрации метаданных (metadata filtering). Фильтрация метаданных позволяет выборочно исплючать или наоборот включать определенные типы объектов во время выполнения задания Data Pump Export или Data Pump Import. В преджней утилите экспорта для указания того, требуется ли экспортировать такие объекты, применялись параметры CONSTRAINTS, GRANTS и INDEXES. За счет использования параметров EXCLUDE и INCLUDE теперь стало можно включать и исключать объекты и многих других видов помимо тех четырех, фильтарцию которых можно было осуществлять ранее. Например, если необходимо сделать так, тобы во время экспорта не экспортировались никакие пакеты, такое поведение задается с помощью параметра EXCLUDE.
Проще говоря, параметр EXCLUDE помогает пропускать определенные типы объектво базы данных во время операции экспорта или импорта, а параметр INCLUDE наоборот – включать в эти операции только определенный набор объектов. Ниже показано, как в общем случае выглядит синтаксис этих параметров:
Параметры EXCLUDE и INCLUDE являются взаимоисключащими. Поэтому во время выполенния одного и того же задания применять можно толкьо какой-то один из них; использовать тот и другой одновременно нельзя.
Как для параметра EXCLUDE, так и для параметра INCLUDE, элемент конструкцияимени является необязательным. Как известно, некоторые объекты в базе данных, например, таблицы, индексы, пакеты и процедуры, обладают именами, а некоторые, напримре, объекты GRANTS – нет. Элемент конструкцияимени в параметре EXCLUDE или INCLUDE позволяет приенять SQL-функцию для фильтрации именованных объектов.
Ниже приведен простой пример исключения всех таблиц, имя которые начинается с ECMP.
В этом примере ”LIKE ‘EMP%’” пре конструкцию имени.
Элемент конструкция_имени является необязательным в параметрах EXCLUDE и INCLUDE. Он представляет собой просто средство фильтрации, позволяющее более точно определять тип подлежащих исключению или включению объектво (индексов, таблиц и т.д.). В случае его пропуска включаться или исключаться будут все объекты указанного типа.
В следующем примере Oracle исключит из операции экспорта все индексы, потому в элементе конструкция_имени не было указано никакого значения, требующего, чтобы исключались только определенные индексы:
Вдобавок параметр EXCLUDE может применяться для исключения целой схемы, как показано в следующем примере:
Параметр INCLUDE является противоположностью параметру EXLCUDE и позволяет принудительно включать в операцию экспорта только определенный набор объектов. Как и в случае параметра EXLCUDE, для указания того, какие точно объекты требуется экспортировать, вместе с INCLUDE тоже можно использовать элемент конструкция_имени.
Ниже приведены три примера, демонстрирующие примеение элемента конструкция_имени для ограничения выбираемых объектов:
В первом примере параметр INCLUDE указывает, что в процессе экспорта должны приниать участие только две таблицы: ECMPLOYEES и DEPARTMENTS, во втором – только процедуры, а в третьем – только индексы, причем лишь те, имя у которых начинается с EMP.
В следующем примере показано, как использовать символ косой черты для отмены двойных кавычек:
При выполнении фильтрации метаданных за счет применения параметра EXCLUDE и INCLUDE нужно помнить о том, что все объекты, которые зависят от какого-то из фильтуемых объектов, будут обрабатываться тем же образом, что и сам этот фильтруемый объект. Например, в случае использвоания параметра EXCLUDE для исключения некоторой таблицы также автоматичеки будут исключаться индексы, граничения, триггеры и прочие зависящие от этой тблицы объеекты.
Существует еще множество всевозможных параметров в т.ч. и шиврование, компрессиия и д.р.
Data Pump Import
Иногда, (в моем случае при неудачном импорте) можно вытащить из файла дампа весь код DDL.
Для этого можно воспользоваться параметром SQLFILE.
Создается файл scott.sql с DDL.
Параметры фильтрации
Параметр CONTENT применяться в Data Pump Import, как и в Data Pump Export, для указания того, должны ли загружаться только строки (CONTENT=DATA_ONLY), строки и метаданные (CONTENT=ALL), либо только метаданные (CONTENT=METADATA_ONLY). Параметры EXLCUDE и INCLUDE имеют в Data Pump Import точно такое же предназначение, как и в Data Pump Export, и явялются взаимоисключающими, а в частности:
- Параметр INCLUDE используется для перечиления объектов, которые необходимо импортировать;
- Параметр EXCLUDE применятьтся для перечисления объектов, которые имортировать не требуется.
Ниже приведент простой пример использования параметра INCLUDE. В этом примере импорт ограничивается только объектами таблиц. В результате импортирована будет только таблица PERSONS.
Для импорта только тех таблиц, имя у которых начинается с букв PER, можно использоть конструкцию INCLUDE=TABLE:”LIKE ‘PER%’”. Вдобавок параметр INCLUDE можно применять и отрицательным образом, указывая то, что все объекты с оперделенным синтаксисом должны игнорироваться: INCLUDE=TABLE:”NOT LIKE ‘PER%’”
Обратите внимаение на то, что в случае установки для параметра CONTENT занчения DATA_ONLY, использовать во время импорта ни параметр EXCLUDE ни параметр INCLUDE нельзя.
Параметр TABLE_EXISTS_ACTION позволяет указывать Data Pump Import, что следует делать в случае, если таблица уже существует. Для этого параметра можно устанавливать четыре разных значения:
- SKIP – (значение по умолчанию) – пропукать таблицу, если таковая уже существует;
- APPEND – присоединять строки к таблице;
- TRUNCATE – усекать таблицу и загружать данные из экспортного файла дампа.
- REPLACE – удалять таблицу, если таковая сущствует, создавать ее заново и снова загружать в нее данные.
Параметры переопределения
Параметр REMAP_TABLE
Параметр REMAP_TABLE позволяет переименовывать таблицу при выполнении операции импорта с сипользованием метода переноса табличных пространств.
В этом примере параметр REMAP_TABLE указывает, что при выполнении операции импорта имя таблицы hr.employees должно быть изменено на hr.emp
Параметр REMAP_SCHEMA
Параметр REMAP_SCHEMA позволяет перемещать объекты из одной схемы в другую. Задается этот параметр примерно так:
В этом примере параметр REMAP_SCHEMA указывает, что при выполнении операции импорта требуется перемесить все объекты из исходной схемы HR в целевую схему OE. Утилита Data Pump Import может даже создать схему OE, если таковой в целевой базе данных не существует.
Параметр REMAP_TABLESPACE
Иногда бывает нужно, чтобы табличное пространство, в которое выполняется импорт даннных, отличалось от используемого в исходной базе данных. Параметр REMAP_TABLESPACE позволяет осуществлять во время импорта перемещение объектов из одного табличноо пространства в другое.
Параметр REMAP_DATAFILE
При перемещении баз данных между двумя различными платформами, на каждой из которых используетс свое соглашие по именованию фалов, параметр REMAP_DATAFIE приходится очень кстати, поскольку позволяет изменять формат именования файлов. Ниже приведен пример, показывающий, как с помощью этого параметра указать утилите Data Pump Import, что вместо формата фаловой системы Windows, требуется использовать формат файловой системы UNIX. После этого при обнаружении в экспортном файле дампа людой ссылки на файл с именем в формате файловой истемы Windows, утилита Data Pump Import будет автоматически изменять имя файла в соответствии с форматом файловой системы UNIX.
Параметры TRANSFORM
Предположим, что требуется импортировать таблицу из другой схемиы или даже другой азы данных и не импортироват при этом другие атрибуты хранения объектов, т.е. необходимо просто перенести содержациеся в таблице данные. Параметр TRASNSFORM позволяет указать утилите Data Pump Import не импортировать оперделенные атрибуты хранения и атрибуты других видов. За счет применения параметра TRANSFORM можно исключать из таблицы или индекса конструкции STORAGE и TABLESPACE или только конструкции STORAGE. При выполнении импорта с помощью Data Pump Oracle создает объекты с использованием DDL-операторов, которые находит в экспортных файлах дампа. Параметр TRANSFORM, по сути, указывает утилите Data Pump Import изменять приводящие к созданию объектов операторы DDL оперделенным образом.
В целом синтаксис параметра TRANSFORM выглядит так:
Ниже приведено краткое описание того, что собой представляет кадый элемент.
1) Название_трансовармации. Существуют всего четыре опции, которые могут указываться на месте этого элемента. Эти опции позволяют, соответственно, изменять четыре основных вида характеристик объекта.
- SEGMENT ATTRIBUTES. Эта опция позволяет влиять на атриуты сегмента, в число которых вхдят физические атрибуты, атрибуты хранения, табличные пространства и журанлы. Принуждать Data Pump Import включать все эти атрибтуы можно, указав на месте название_трансформации этой опции со значением Y (SEGMENT_ATTRIBUTES=Y), которое является для этого параметра значением по умолчанию. В таком случае Data Pump Import будет включать все четыре атрибута сегмента вместе с их операторами DDL.
- STORAGE. За счет указания на месте название_трансформации опции STORAGE со значением Y (STORAGE=Y), представляющее собой значение по умолчанию, можно получать лишь атрибуты хранения тех объектов, которые являются частью задания Data Pump Import.
- OID. В случае указания на месте название_трансформации опции OID со значением Y (OID=Y), которое является для нее значением по умолчанию, объектым таблицам во время импорта будет приваиваться новй OID.
- PCTSPACE. За счет указания на месте название_трансформации опции PCTSPACE с положительным числом в качестве значения можно увеличивать выделяемый под объекты и файлы данных объем пространства на соответствующее количество процентов.
2) Значение. На месте элемента значение в параметре TRANSFORM может указываться либо значение Y (да), либо значение N (нет). Как упоминалось выше, для первых трех опций, которые могут указываться на месте название_трансформации, по умолчанию устанавливается занчение Y. Это означает, что по умолчанию Data Pump предусмативает выполнение импорта как атрибутов сегмента, так и атрибутов хранения объекта. В качестве альтернативного варианта, для этих опций можно устанавивать значение N и тем самым указывать Data Pump не импортировать исходные атрибуты сегмента и/или хранения. Что касается опции PCTSPACE, то для нее на месте элемета занчение можнет задваться только какое-то число.
3) Типобъекта.</strong> На месте элемета типобъекта можно указывать утилите Data Pump Import, объекты какого типа необходимо трансформировать. Это могут быть таблицы, индексы, табличные пространсва, типы, кластеры, граничения и прочие обхекты, в зависимости от опций, указываемых на месте название_транформации. В случае не указания типа подлежащих транформаци обхектов при использовании опции SEGMENT_ATTRIBUTES и STORAGE, эти опции будут применяться ко всем таблицам и индексам, которые являются частью операции импорта.
Ниже приведен пример применения параметра TRANSFORM:
В этом примере для SEGMENT_ATTRIBUTES установлено занчение N, а в качестве типа объекта указана таблица. В такой спецификации параметр TRANSFROM указывает утилите Data Pump Import не импортировать существующие атрибуты хранения ни для каких таблиц.
Мониторинг выполнения заданий Data Pump
Наиболее важными для мониторинга за выполнением заданий Data Pump являются представления DBA_DATAPUMP_JOBS и DBA_DATAPUMP_SISSIONS.
Представление DBA_DATAPUMP_JOBS позволяет получать сводную информацию обо всех выполняющихся в текущий момент заданиях Data Pump.
Представление DBA_DATAPUMP_SESSIONS позволяет выяснять, какие пользователькие сеансы в текущий момент подключены к заданию Data Pump Export или Data Pump Import
Просмотр информации о ходе выполненния заданий Data Pump
Ниже приведен типичный сценарий, который можнро использовать для получения информаци о том, сколько времени осталось до завершения выполнения задания Data Pump:
1- Import и Export в Oracle 11g
Начиная с Oracle 11 и далее Oracle использует синтаксис отличающийся от предыдущей версии Oracle чтобы импортировать (import) и экспортировать (export) данные. В целом есть 2 варианта для импорта/экспорта (import/export):
- Import/Export некоторые таблицы CHEMA.
- Import/Export полностью SCHEMA (включая объекты: table, view, function. )
1.1- Import/Export SCHEMA (11g)
Для начала вам нужно определить DBA Directory (Папку DBA, можно сказать папку управленияị DB) она прикрепляется к реальному пути к вашему диску. На самом деле вам нужно объявить один раз и можете использовать дальше.
Например я определю DBA Directory (Папку DBA) с названием MY_BACKUP_DIR прикрепляя к файлу C:/oraclebackup
Войти в SQL Plus используя user system:
DBA Directory создан с помощью user system. Только user с авторизацией DBA могут ее использовать. Вы так же можете дать авторизацию для использования этой DBA Directory другим пользователям.
Можете так же сделать запрос чтобы увидеть созданные до этого объекты DBA Directory и имеющиеся в Oracle.
1.1.1- Expdp
Использовать expdp чтобы экспортировать (export) полностью SCHEMA в файл dump.
Чтобы экспортировать (export) вам нужно открыть CMD и CD к папке BIN в Oracle.
Заметка: Вы можете экспортировать (export) несколько Schema одновременно в 1 файл dump. Например:
1.1.2- Impdp
Для начала вам нужно создать user learningsql2. Войти в SQL Plus:
В принципе вы только что создали пустую SCHEMA.
Далее мы импортируем (import ) из файла dump в только что созданную Schema. На самом деле в файле dump может быть одна или несколько SCHEMA. Когда вы импортируете (import) файл dump в определенную Schema, вам нужно указать источник SCHEMA в файле dump, и целевую SCHEMA.
Заметьте, что в ORACLE название SCHEMA так же является названием User.
Откройте CMD и CD в папку bin в Oracle:
- Импорт из файла learningsql.DMP
- Из источника Schema: learningsql (В файле dump)
- К целевой Schema: learningsql2
Заметка: Вы можете не создавать до этого user learningsql2, команда impdb сама создаст этот user, но пароль не определен, вам нужно самим установить пароль.
View more Tutorials:
Это онлайн курс вне вебсайта o7planning, который мы представляем, он включает бесплатные курсы или курсы со скидкой.
Читайте также: