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
Новые статьи и публикации
- 2025-03-14 » SPF-запись
- 2025-03-07 » SEO на маркетплейсах: как оптимизировать карточку товара для поисковой выдачи
- 2025-02-18 » Топ-10 бесплатных нейросетей для генерации изображений: лучшие ии генераторы 2024 года
- 2025-02-11 » Критическая уязвимость в 1С-Битрикс
- 2025-02-11 » Google Search Console: руководство для начинающих вебмастеров
- 2025-02-11 » Методы измерения результативности рекламных кампаний: плюсы и минусы
- 2025-02-11 » Тренды SEO в 2025 году
- 2025-02-10 » Свой Google в локалке. Ищем иголку в стоге сена
- 2025-01-29 » SEO — это комплексная работа. Шесть главных факторов ранжирования сайтов
- 2025-01-29 » Гайд для главной страницы e-commerce сайта: как оформить, чтобы повысить конверсию
- 2025-01-20 » Krea AI выпустила бесплатную функцию преобразования изображений в 3D-объекты — их можно вращать и вписывать в фотографии
- 2025-01-19 » Отзывы на Яндекс Картах: как пройти модерацию
- 2025-01-15 » Топ-6 лучших российских нейросетей, в которых можно генерировать тексты и изображения бесплатно и без VPN
- 2025-01-14 » 15 бесплатных способов узнать, чем интересуется ваша аудитория
- 2025-01-11 » Бездепозитные бонусы в казино за регистрацию с выводом: особенности и возможности получения
- 2025-01-09 » Новая модель LAM способна выполнять задачи в Word
- 2024-12-26 » Универсальный промпт для нейросети: как выжать максимум из ChatGPT, YandexGPT, Gemini, Claude в 2025
- 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 » Интеграция с Яндекс Еда
Всегда храни верность своему начальнику - следующий, может быть еще хуже... |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.
Или напишите нам в WhatsApp
Или напишите нам в WhatsApp