Оракл для начинающих. Оракл для чайников. Советы, вопросы, литература, книги, ссылки, cкачать, faq, сертификация, с чего начать, основы, SQL,. Практический вебинар, который прошел 23. В начале видео технические неполадки Время требует эффективности и. SQL Maestro для MySQL инструмент для администрирования. PostgreSQL, MSAccess, MSSQL Server, Oracle и других БД. Как ответить запросом на запрос, или Базы данных не для чайников. Toad for MySQL забыли бесплатный и очень функциональный. Обычно SQLPlus используется для незапланированного ввода ко манд. Инструментальное средство TOAD Tool for Oracle Application De. Для реализации нашей базы необходимо создать четыре таблицы Заказ, Позиции заказа, Клиент, Изделие. Теперь определимся со структурой таблиц. Таблица. То же самое относительно связи ЗаказПозиции заказа одному Заказу соответствует много Позиций, в то время как одна и та же Позиция может входить только в один Заказ и связи ЗаказКлиент один Клиент может делать много Заказов, в то время как одному Заказу соответствует только один Клиент. Но эти правила ограничения предметной области могут меняться в разных ситуациях. Например, заказ могут выполнять несколько клиентов бывает и такое. Но в нашем проекте мы примем именно такой вариант, для простоты проектирования. Итак, схема нашей будущей базы готова, это так сказать скелет будущей информационной системы. Далее я покажу как реализовать данную схему в СУБД Oracle. Вкратце расскажу про Oracle. В этой СУБД иногда звучит название сервер, пользователь работает с объектами, основными из которых являются точнее которые необходимы нам Таблицы основные таблицы, которые составляют базу данных Индексы индекс создатся по столбцу или набору столбцов Представления виртуальные таблицы, основанные на SQL запросах Последовательности генератор последовательностей Oracle используется для автоматической выработки уникальной последовательности чисел в КЭШе счтчик Функции представляют собой набор операторов языка SQl или PLSQL Процедуры отличаются от функций тем, что не возвращают результата Триггеры это код программа, который хранится в базе данных и вызывается событиями например, вставка данных в таблицу. Создавать таблицы будем в схеме SCOTT, это учебная схема, которая создатся по умолчанию при установке сервера, пароль для данной схемы TIGER. Осуществлять вс это будем средствами Sql Plus, я предпочитаю графические средства командной строке, хотя возможен и вариант из командной строки. Хотя существует множество визуальных средств для работы с СУБД Oracle от сторонних разработчиков, я, например, люблю пользоваться продуктом Quest Software TOAD. В этой программе есть средства для создания объектов БД, администрирования, изучения структур БД, конструирования запросов и т. В общем, советую посмотреть. Итак, при запуске Sql Plus требуется ввести имя пользователя, пароль и базу, к которой будем подсоединяться У меня база называется MANUF, вы введите имя вашей базы. После удачного соединения нам понадобится выполнить так называемые скрипты это файлы в которых содержится текст SQL конструкций объектов БД таблиц, последовательностей и т. Но прежде нам необходимо создать эти скрипты, здесь необходимо знание языка SQL. В общем, не буду затягивать, а сразу представлю текст скриптов создания таблиц и связей ограничений ссылочной целостности с комментариями. Для таблицы КЛИЕНТ CREATE TABLE KLIENT. ID. Конструкция CREATE TABLE создат таблицу я думаю вы и без меня это поняли, в скобках перечисляются столбцы создаваемой таблицы, соответственно указывается наименование столбца, тип данных при необходимости размер, значение по умолчанию default, ограничения на значение not null значение д. Таким образом, накладывая определнные ограничения мы предусматриваем вероятность того что пользователь забудет ввести данные, которые обязательно должны быть введены, за этим будет следить СУБД. Согласитесь, заказ без номера это не заказ, по крайней мере там где я работаю это именно так, без номера заказа никто и пальцем не пошевелит. Конструкция CREATE UNIQUE INDEX создат индекс в таблице, он нужен для ускоренного поиска, сортировки данных в столбце. Индексировать обязательно ключевые столбцы, и столбцы по которым чаще всего происходит поиск, сортировка данных например, в запросах. Конструкция ALTER TABLE имя. Например, в таблице Заказ связь с таблицей Клиент происходит через столбец ID. После создания данного ключа удаление клиента при привязке его хотя бы к одному заказу будет невозможно. Таким образом реализуется обеспечение непротиворечивости данных в базе. Например, вы создали заказ, привязали к нему позиции, а после этого случайно или осознанно удалили заказ, таким образом, эти позиции потеряют связь с определнным заказом, и не будут связаны ни с одним из них, получается, база находится в противоречивом состоянии позиции есть, а заказа нет. А теперь представьте в приложении в форме Журнала заказов для выбранного заказа отображаются только привязанные к нему позиции, т. Для того чтобы удалить нужного клиента необходимо будет удалить все связанные с ним заказы, т. Это и есть так называемые ограничения предметной области, о которых я так часто упоминаю. Ну ладно это вс лирика, продолжим. Далее нам необходимо будет реализовать столбцы счтчики, это выполняется с помощью следующих конструкций Для таблицы КЛИЕНТ create sequence KLIENT. Для вставки значения последовательности применяется триггер, который срабатывает до вставки строки BEFORE INSERT. Таким образом, мы обеспечиваем уникальность вводимых значений в ключевое поле. Теперь мы закончили наконец то с базой данных и можно приступать к созданию нашего приложения, так сказать оболочки нашей информационной системы. Загружаем Delphi и создам новое приложение File New VCL Forms Application учтите что это 1. File New Application. Для реализации нашей системы я буду использовать компоненты доступа к данным разработанные фирмой Borland BDE. Как бы ни ругали эти компоненты, я считаю что они обеспечивают максимальные возможности предоставляемы данной средой разработки. Остальные механизмы связи с данными накладывают определнные ограничения на их использование, хотя в принципе вс зависит от решаемых задач, возможно в другом случае будет эффективнее использовать db. Express например, Borland рекомендует использовать эти компоненты при создании распределнных приложений. Назовм нашу главную форму Журнал регистрации заказов свойство Caption. Итак, на главную форму необходимо добавить компонент Data. Base с закладки BDE. Затем двойным щелчком мыши на данном компоненте открываем окно свойств Здесь в поле name пропишем имя нашей базы я написал имя моей БД manuf, можно написать любое, и в поле Driver name выбрать драйвер ORACLE, затем нажимаем кнопку Defaults для добавления параметров по умолчанию. Соответственно в окне редактирования появится список параметров, там удаляем вс кроме SERVER NAME, USER NAME и PASSWORD. Для параметра SERVER NAME пишем имя нашей БД в системе, USER NAME и PASSWORD соответственно SCOTTTIGER. Также снимем галочки со свойств Login prompt запрос пользователя и пароля, и Keep inactive connection чтобы соединение не было открыто постоянно и нажимаем ОК. Вс, свойства соединения с БД настроены, можно установить свойство нашего Data. Base Connected в true для проверки связи, в случае если связь настроена неправильно, вылетит соответствующее сообщение.