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
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2024-11-26 » Капитан грузового судна, или Как начать использовать Docker в своих проектах
- 2024-11-26 » Обеспечение безопасности ваших веб-приложений с помощью PHP OOP и PDO
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-22 » Ошибки в Яндекс Вебмастере: как найти и исправить
- 2024-11-15 » Перенос сайта на WordPress с одного домена на другой
- 2024-11-08 » OSPanel 6: быстрый старт
- 2024-11-08 » Как установить PhpMyAdmin в Open Server Panel
- 2024-09-30 » Как быстро запустить Laravel на Windows
- 2024-09-25 » Next.js
- 2024-09-05 » OpenAI рассказал, как запретить ChatGPT использовать содержимое сайта для обучения
- 2024-08-28 » Чек-лист: как увеличить конверсию интернет-магазина на примере спортпита
- 2024-08-01 » WebSocket
- 2024-07-26 » Интеграция с Яндекс Еда
- 2024-07-26 » Интеграция с Эквайринг
- 2024-07-26 » Интеграция с СДЕК
- 2024-07-26 » Интеграция с Битрикс-24
- 2024-07-26 » Интеграция с Travelline
- 2024-07-26 » Интеграция с Iiko
- 2024-07-26 » Интеграция с Delivery Club
- 2024-07-26 » Интеграция с CRM
- 2024-07-26 » Интеграция с 1C-Бухгалтерия
- 2024-07-24 » Что такое сторителлинг: техники и примеры
- 2024-07-17 » Ошибка 404: что это такое и как ее использовать для бизнеса
- 2024-07-03 » Размещайте прайс-листы на FarPost.ru и продавайте товары быстро и выгодно
- 2024-07-01 » Профилирование кода в PHP
- 2024-06-28 » Изучаем ABC/XYZ-анализ: что это такое и какие решения с помощью него принимают
- 2024-06-17 » Зачем вам знать потребности клиента
- 2024-06-11 » Что нового в работе Яндекс Метрики: полный обзор обновления
- 2024-06-11 » Поведенческие факторы ранжирования в Яндексе
- 2024-06-11 » Скорость загрузки сайта: почему это важно и как влияет на ранжирование
Всегда храни верность своему начальнику - следующий, может быть еще хуже... |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.