| // |
| // Licensed to the Apache Software Foundation (ASF) under one |
| // or more contributor license agreements. See the NOTICE file |
| // distributed with this work for additional information |
| // regarding copyright ownership. The ASF licenses this file |
| // to you under the Apache License, Version 2.0 (the |
| // "License"); you may not use this file except in compliance |
| // with the License. You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, |
| // software distributed under the License is distributed on an |
| // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| // KIND, either express or implied. See the License for the |
| // specific language governing permissions and limitations |
| // under the License. |
| // |
| |
| = Создание приложения на основе базы данных на языке PHP |
| :jbake-type: tutorial |
| :jbake-tags: tutorials |
| :jbake-status: published |
| :icons: font |
| :syntax: true |
| :source-highlighter: pygments |
| :toc: left |
| :toc-title: |
| :description: Создание приложения на основе базы данных на языке PHP - Apache NetBeans |
| :keywords: Apache NetBeans, Tutorials, Создание приложения на основе базы данных на языке PHP |
| |
| = Урок 1б: создание таблиц базы данных Oracle |
| :jbake-type: tutorial |
| :jbake-tags: tutorials |
| :jbake-status: published |
| :icons: font |
| :syntax: true |
| :source-highlighter: pygments |
| :toc: left |
| :toc-title: |
| :description: Урок 1б: создание таблиц базы данных Oracle - Apache NetBeans |
| :keywords: Apache NetBeans, Tutorials, Урок 1б: создание таблиц базы данных Oracle |
| |
| |
| В данном уроке описывается последний подготовительный этап разработки приложения "Wish List" ("Список желаний") в рамках создания демонстрационной базы данных с тестовыми данными. Для выполнения всех этапов, предложенных в данном руководстве, необходима база данных, которая позволит сохранять данные (желания), введенные пользователями. IDE NetBeans позволяет выполнять все эти действия с помощью интерфейса IDE. |
| Перед началом работы ознакомьтесь с требованиями, описанными в разделе link:wish-list-tutorial-main-page.html[+Создание приложения типа CRUD на языке PHP – главная страница+]. |
| |
| Текущий документ является частью краткого учебного курса "Создание приложения CRUD в IDE NetBeans для PHP". |
| |
| |
| |
| == Создание пользователя базы данных |
| |
| В рамках этой процедуры вы сначала создаете пользователя, а затем – таблицы в качестве этого пользователя. |
| |
| Пользователя можно создать либо с помощью средств Oracle или путем соединения IDE NetBeans с базой данных и использования SQL IDE. Среда NetBeans 7.0, в настоящее время доступная в виде разработки или бета-версии, предоставляет усовершенствованные возможности подключения к базам данных Oracle. Для получения дополнительных сведений о соединении IDE NetBeans с базой данных Oracle и создании пользователя в этой базе данных см. краткий учебный курс link:../ide/oracle-db.html[+Соединение с базой данных Oracle+]. |
| |
| Используя выбранное средство, создайте следующего пользователя: |
| |
| |=== |
| |Имя пользователя |phpuser |
| |
| |Пароль |phpuserpw |
| |
| |Системные привилегии |CREATE TABLE |
| |
| |CREATE VIEW |
| |
| |CREATE SEQUENCE |
| |
| |CREATE TRIGGER |
| |
| |Роли (база данных Oracle 10.x) |CONNECT |
| |
| |RESOURCE |
| |=== |
| |
| Ниже приведен пример набора команд SQL для создания этого пользователя. Для выполнения этих команд предполагается, что в базе данных имеются табличные пространства USERS и TEMP. |
| |
| |
| [source,sql] |
| ---- |
| |
| drop user phpuser cascade; |
| create user phpuser identified by phpuserpw; |
| grant connect, resource to phpuser; |
| alter user phpuser default tablespace users temporary tablespace temp account unlock; |
| ---- |
| |
| |
| == Разработка структуры демонстрационной базы данных |
| |
| Для размещения и сохранения всех необходимых данных требуются две таблицы: |
| |
| * таблица "wishers" для сохранения имен и паролей зарегистрированных пользователей; |
| * таблица "wishes", которая будет содержать описания требований. |
| |
| image::images/wishlist-db.png[] |
| |
| Таблица "wishers" содержит три поля: |
| |
| 1. "id" – уникальный идентификатор пользователя. Это поле используется в качестве первичного ключа. |
| 2. "name" – имя |
| 3. "password" – пароль |
| |
| Таблица "wishes" содержит четыре поля: |
| |
| 1. "id" – уникальный идентификатор пользователя. Это поле используется в качестве первичного ключа. |
| 2. "wisher_id" – идентификатор пользователя, оставившего пожелание. Это поле используется в качестве внешнего ключа. |
| 3. "description"– описание |
| 4. "due_date" – требуемая дата исполнения пожелания. |
| |
| Таблицы связаны посредством идентификатора пользователя. Все поля таблицы "wishes" являются обязательными для заполнения, за исключением "due_date". |
| |
| |
| == Создание схемы базы данных Oracle |
| |
| 1. Зарегистрируйтесь в базе данных в качестве только что созданного пользователя. |
| |
| При соединении с помощью IDE NetBeans создайте соединение с использованием новых имени пользователя и пароля. Убедитесь в том, что выбрана схема с именем пользователя. (См. раздел link:../ide/oracle-db.html#connect[+Установка подключения к базе данных Oracle+] учебного курса "Подключение к базе данных Oracle"). |
| |
| |
| [start=2] |
| . Чтобы создать таблицу wishers, выполните следующий запрос SQL: |
| |
| [source,sql] |
| ---- |
| |
| create table wishers (id number not null,name varchar2(50) unique not null, password varchar2(50) not null, constraint wishers_pk primary key(id)); |
| ---- |
| |
| [start=3] |
| . Чтобы создать таблицу wishes, выполните следующий запрос SQL. Обратите внимание на то, что для связывания пожеланий и пользователей, оставивших пожелания, создается внешний ключ. |
| |
| [source,sql] |
| ---- |
| |
| create table wishes (id number not null, wisher_id number not null,description varchar2(255) not null, due_date date, constraint wishes_pk primary key(id), constraint wishes_fk1 foreign key(wisher_id) references wishers(id)); |
| ---- |
| |
| [start=4] |
| . Убедитесь в том, что к базе данных добавлены новые таблицы. При соединении с базой данных с помощью IDE NetBeans перейдите в окне 'Службы' к узлу соединения jdbc:oracle:thin:@localhost:1521:XE [phpuser on PHPUSER]. Новые таблицы приведены в узле "Tables" (Таблицы). (Если они не отображаются, щелкните подключение правой кнопкой мыши и выберите команду "Refresh" (Обновить)). |
| |
| image::images/tables-in-services-window.png[] |
| |
| Примечание. Набор команд SQL для создания таблиц базы данных Oracle можно загрузить link:https://netbeans.org/projects/www/downloads/download/php%252FSQL-files-for-Oracle.zip[+здесь+]. |
| |
| |
| == Добавление последовательностей и триггеров для увеличения значений идентификаторов |
| |
| В базе данных Oracle необходимо указать последовательность для увеличения значения. Для увеличения значения при добавлении нового элемента в таблицу следует добавить триггер. |
| |
| 1. Чтобы добавить последовательность для таблицы wishers, выполните следующую команду SQL: |
| |
| [source,sql] |
| ---- |
| |
| create sequence wishers_id_seq start with 1 increment by 1; |
| ---- |
| |
| [start=2] |
| . Чтобы инициировать последовательность в столбце идентификаторов таблицы wishers при добавлении нового пользователя, оставившего запись, выполните следующую команду SQL: |
| |
| [source,sql] |
| ---- |
| |
| create or replace trigger wishers_insert |
| before insert on wishers |
| for each row |
| begin |
| select wishers_id_seq.nextval into :new.id from dual; |
| end; |
| / |
| ---- |
| |
| [start=3] |
| . Добавьте последовательность для таблицы wishes. |
| |
| [source,sql] |
| ---- |
| |
| create sequence wishes_id_seq start with 1 increment by 1; |
| ---- |
| |
| [start=4] |
| . Добавьте триггер, запускающий последовательность в столбце идентификаторов таблицы wishes при добавлении нового пожелания. |
| |
| [source,sql] |
| ---- |
| |
| create or replace trigger wishes_insert |
| before insert on wishes |
| for each row |
| begin |
| select wishes_id_seq.nextval into :new.id from dual; |
| end; |
| / |
| ---- |
| |
| Примечание. Набор команд SQL для создания таблиц базы данных Oracle, включая последовательности и триггеры, можно загрузить link:https://netbeans.org/projects/www/downloads/download/php%252FSQL-files-for-Oracle.zip[+здесь+]. |
| |
| |
| == Ввод тестовых данных |
| |
| Для тестирования приложения необходимо наличие некоторых данных в базе данных. В приведенном ниже примере показано, каким образом можно добавить данные для двух пользователей и четырех желаний. |
| |
| 1. Добавьте пользователя с именем Tom и паролем "tomcat". |
| |
| [source,sql] |
| ---- |
| |
| insert into wishers (name, password) values ('Tom','tomcat'); |
| ---- |
| |
| [start=2] |
| . Добавьте пользователя с именем Jerry и паролем "jerrymouse". |
| |
| [source,sql] |
| ---- |
| |
| insert into wishers (name, password) values ('Jerry', 'jerrymouse');commit; |
| ---- |
| |
| [start=3] |
| . Добавьте пожелания. |
| |
| [source,sql] |
| ---- |
| |
| insert into wishes (wisher_id, description, due_date) values (1, 'Sausage', to_date('2008-04-01', 'YYYY-MM-DD')); |
| insert into wishes (wisher_id, description) values (1, 'Icecream');insert into wishes (wisher_id, description, due_date) values (2, 'Cheese', to_date('2008-05-01', 'YYYY-MM-DD')); |
| insert into wishes (wisher_id, description)values (2, 'Candle'); |
| commit; |
| ---- |
| |
| [start=4] |
| . Убедитесь в том, что данные добавлены. При использовании IDE NetBeans для просмотра данных проверки, щелкните правой кнопкой мыши соответствующую таблицу и выберите в контекстном меню 'Просмотреть данные'. |
| |
| image::images/view-test-data.png[] |
| |
| Ознакомиться с общими принципами организации баз данных и их моделями можно с помощью следующего обучающего руководства: link:http://www.tekstenuitleg.net/en/articles/database_design_tutorial/1[+http://www.tekstenuitleg.net/en/articles/database_design_tutorial/1+]. |
| |
| Дополнительные сведения о синтаксисе операторов Oracle ``CREATE TABLE`` приведены в разделе link:http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/statements_7002.htm[+http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/statements_7002.htm+]. |
| |
| Примечание. Набор команд SQL для создания таблиц базы данных Oracle можно загрузить link:https://netbeans.org/projects/www/downloads/download/php%252FSQL-files-for-Oracle.zip[+здесь+]. |
| |
| |
| == Что дальше? |
| |
| link:wish-list-lesson2.html[+Следующий урок >>+] |
| |
| link:wish-list-tutorial-main-page.html[+Назад на главную страницу руководства+] |
| |
| |
| link:/about/contact_form.html?to=3&subject=Feedback:%20PHP%20Wish%20List%20CRUD%201:%20Create%20Oracle%20Database%20Tables[+Мы ждем ваших отзывов+] |
| |
| |
| Для отправки комментариев и предложений, получения поддержки и новостей о последних разработках, связанных с PHP IDE NetBeans link:../../../community/lists/top.html[+присоединяйтесь к списку рассылки users@php.netbeans.org+]. |
| |
| link:../../trails/php.html[+Возврат к учебной карте PHP+] |
| |