CakePHP с нуля: генератор Bake строит приложения с отношениями в таблицах. Часть 6 из 10

В данном уроке, который является продолжением серии, посвященной CakePHP, мы продолжим построение приложения для доски объявлений о вакансиях. В конечном итоге, по завершении серии уроков, посетитель веб проекта сможет размещать объявления в определенных категориях, выводить список вакансий, фильтровать его и проводить по нему поиск, а также регистрироваться в нашей системе.

В прошлом уроке мы создали несколько таблиц для нашего приложения, но ниже предлагается другой вариант с другими полями. Так что, следует обновить базу данных:

CREATE TABLE IF NOT EXISTS `categories` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM;

CREATE TABLE IF NOT EXISTS `jobs` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `category_id` int(11) NOT NULL,
  `user_id` int(11) NOT NULL,
  `title` varchar(250) COLLATE utf8_unicode_ci DEFAULT NULL,
  `body` text COLLATE utf8_unicode_ci,
  `company` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `job_type` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL,
  `created` datetime DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM;

CREATE TABLE IF NOT EXISTS `users` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `pass` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `name` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
  `location` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `address` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `email` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  `web` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM;

Мы сгенерируем рабочие файлы для всех трех таблиц, чтобы установить между ними отношения. Посмотрите на структуру таблицы Jobs. В ней используются два поля category_id и user_id. Данные поля используются для создания отношений (ассоциаций) между таблицами.

Соглашение об именовании должно соблюдаться, чтобы генератор Bake создал правильные отношения. Поле, участвующее в отношениях,  должно иметь имя, которое является единственным числом имени таблицы, с которой будет устанавливаться отношение, и суффикса id  (таблица называется Categories, значит поле будет называться category_id).

Итак. Переходим в командную строку, переключаемся в папку проекта и запускаем генератор командой cake bake. Вводим M для создания модели  и выбираем конфигурацию базы данных по умолчанию. Вводим 1 для генерации модели для таблицы Categories. Скрипт спросит о необходимости создания критериев проверки данных. Ответим на запрос утвердительно и выберем опцию 28 для поля id и 19 (not empty) для поля name.

Затем скрипт Bake запросит нас о построении ассоциаций модели. Введем y и нажмем Enter. Bake спросит о подтверждении отношения одной категории ко многим вакансиям (Category hasMany Job), что действительно соответствует нашему приложению. Отвечаем утвердительно.

Затем отказываемся от предложения построить дополнительные ассоциации и подтверждаем сгенерированную модель. Если вы строили приложение по предыдущему уроку, то Bake будет запрашивать разрешение на изменение файлов - подтвердите запросы, чтобы изменения попали в приложение.

Мы по прежнему пропускаем запросы на создание SimpleTest (отвечаем на них "нет").

Теперь построим модель для вакансий (Job). Выбираем M для генерации модели, 2 для определения модели Job. устанавливаем правила проверки: для поля id - 28, для полей category_id и users_id  - 19 (not empty), также можно установить 19 (not empty) для полей title, body, company и job_type.

Затем перейдем к созданию ассоциаций. Bake выдаст запрос о том, что вакансия принадлежит категории (Job belongs to Category), подтверждаем его. Также подтверждаем запрос о том, что вакансия принадлежит пользователю (Job belongs to User).

Теперь проделываем операцию создания модели с заданием критериев проверки и установления отношений для таблицы пользователей (User). изображение ниже показывает результат работы Bake:

Теперь строим контроллеры для нашего приложения. Вводим C для запуска генерации контроллера, подтверждаем использование конфигурации базы данных по умолчанию. Выбираем контроллер для генерирования. Опции, которые используются для генерации контроллера, можно подсмотреть на изображении ниже (генерируется контроллер для категорий):

Проводим аналогичные действия для двух других контроллеров нашего приложения. 

Затем нужно сгенерировать виды. На изображении ниже приведены опции, которые были выбраны для генерации вида для категорий. Аналогичные опции выбираются для генерации видов для двух других контроллеров.

После построения видов для двух других контроллеров наше приложение готово к работе.

В браузере укажите адрес вашего приложения в совокупности с контроллером (например, http://localhost/cake/categories) и проверьте действие функций:

Несмотря на то, что функционал получившегося приложения вполне работоспособен, законченным его считать нельзя. В следующем уроке мы займемся тонкой настройкой сгенерированного кода (подправим сообщения об ошибках и так далее).

Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/gLedbyViVKs/lessons.php

Читать комменты и комментировать

Добавить комментарий / отзыв



Защитный код
Обновить

CakePHP с нуля: генератор Bake строит приложения с отношениями в таблицах. Часть 6 из 10 | | 2012-06-19 12:10:19 | | Статьи Web-мастеру | | В данном уроке, который является продолжением серии, посвященной CakePHP, мы продолжим построение приложения для доски объявлений о вакансиях. В конечном итоге, по завершении серии уроков, посетитель | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: