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-04-22 » Комментирование кода и генерация документации в PHP
- 2024-04-22 » SEO в России и на Западе: в чем основные отличия
- 2024-04-22 » SEO для международного масштабирования
- 2024-04-22 » Как использовать XML-карты для продвижения сайта
- 2024-04-22 » Цифровой маркетинг: инструменты для продвижения и рекламы в 2024 году
- 2024-04-22 » Что такое CSS-модули и зачем они нам?
- 2024-04-17 » 23 сервиса для эффективного экспресс-аудита любого сайта
- 2024-04-08 » Яндекс переходит на новую версию Wordstat
- 2024-04-08 » Яндекс интегрировал в свой облачный сервис эмпатичную нейросеть
- 2024-04-08 » Новая версия нейросети Claude превзошла по мощности аналоги Google и OpenAI
- 2024-04-08 » Как пользоваться GPT 4 и Claude бесплатно и без VPN
- 2024-03-13 » Стратегии SEO на 2024 год
- 2024-03-13 » Как использовать анимацию с помощью JavaScript-библиотеки GSAP
- 2024-03-13 » Использование GSAP 3 для веб-анимации
- 2024-03-13 » Cогласование топографической съёмки с эксплуатирующими организациями
- 2024-02-19 » Теряются лиды? Как настроить сквозную аналитику
- 2024-02-17 » Мерч и IT: на что обратить внимание в 2024 году
- 2024-02-16 » Копируем с RSync: основные примеры синхронизации файлов
- 2024-02-15 » Лучшие noCode AI платформы для создания диалоговых ботов
- 2024-02-14 » Факторы ранжирования Google 2024 — исследование Semrush
- 2024-02-12 » Перенос сайта на другой хостинг
- 2024-02-05 » В России сформирован реестр хостинг-провайдеров
- 2024-02-04 » Использование SSH для подключения к удаленному серверу Ubuntu
- 2024-02-03 » Подключаемся к серверу за NAT при помощи туннеля SSH. Простая и понятная инструкция
- 2024-02-02 » Настройка CI/CD для Gitlab-репозитория: схемы и гайд по шагам
- 2024-02-01 » GitLab CI Pipeline. Запуск сценария через SSH на удаленном сервере
- 2024-01-29 » Introduction to GitLab’s CI/CD for Continuous Deployments
- 2024-01-26 » Настройка GitLab CI/CD
- 2024-01-25 » Установка shell gitlab runner
- 2024-01-25 » Установка и регистрация gitlab-runner в docker контейнере
Самое важное в каждом деле – пересилить момент, когда нам не хочется работать. И. Павлов |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.