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, мы продолжим построение приложения для доски объявлений о вакансиях. В конечном итоге, по завершении серии уроков, посетитель |
РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-12-02 » Когда ошибка молчит: как бессмысленные сообщения ломают пользовательский опыт
- 2025-12-02 » 9 лучших бесплатных фотостоков
- 2025-12-02 » UTM-метки: ключевой инструмент аналитики для маркетолога
- 2025-12-02 » ПромоСтраницы Яндекса: Что такое и для чего служит
- 2025-12-02 » Метатеги для сайта: исчерпывающее руководство по Title, Description, Canonical, Robots и другим тегам
- 2025-11-26 » Оценка эффективности контента: превращаем информационный балласт в рабочий актив
- 2025-11-26 » 10 причин высокого показателя отказов на сайте
- 2025-11-26 » Когда и зачем обновлять структуру сайта
- 2025-11-26 » Скрытые демотиваторы: как мелочи разрушают эффективность команды
- 2025-11-26 » Зачем запускать MVP и как сделать это грамотно?
- 2025-11-20 » Половина российских компаний сократит расходы на транспорт и маркетинг в 2026 году
- 2025-11-20 » Перенос сайта с большим количеством ссылок
- 2025-11-20 » Перелинковка сайта: Что такое и как ее использовать
- 2025-11-20 » Критерии выбора SEO-специалиста и подрядчика для продвижения сайта
- 2025-11-20 » Применение искусственного интеллекта в рекламных агентствах: комплексное исследование трендов 2025 года
- 2025-11-19 » Геозапросы по-новому: как покорить локальное SEO с помощью ИИ
- 2025-11-14 » Консалтинг: сущность и ключевые направления
- 2025-11-14 » Онлайн-формы: универсальный инструмент для сбора обратной связи
- 2025-11-14 » Факторы конверсии органического трафика
- 2025-11-14 » Планирование рекламного бюджета: самостоятельный подход
- 2025-11-14 » Авторизация на сайте: как выбрать решение для удержания клиентов и сохранения продаж
- 2025-11-13 » Эффективные методы стимулирования клиентов к оставлению положительных отзывов
- 2025-11-13 » Налоговая реформа — 2026: грядущие изменения для предпринимателей
- 2025-11-13 » Альтернативы мессенджерам: что выбрать вместо Telegram и WhatsApp
- 2025-11-13 » Маркировка рекламы для начинающих: полное руководство по требованиям ЕРИР
- 2025-11-13 » ИИ не отберет вашу работу — её займет специалист, владеющий искусственным интеллектом
- 2025-10-29 » Как оценить эффективность работы SEO-специалиста: практическое руководство для маркетологов и владельцев бизнеса
- 2025-10-29 » Киберспорт как маркетинговый инструмент: стратегии привлечения геймеров
- 2025-10-29 » Как говорить с аудиторией о сложном
- 2025-10-29 » Что такое доказательства с нулевым разглашением (ZKP) и их роль в блокчейне
Лично я люблю землянику со сливками, но рыба почему-то предпочитает червяков. Вот почему, когда я иду на рыбалку, я думаю не о том, что люблю я, а о том, что любит рыба. (Дейл Карнеги / БИЗНЕС) |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.


Мы создаем практически любые сайты от продающих страниц до сложных, высоконагруженных и нестандартных веб приложений! Наши сайты это надежные маркетинговые инструменты для успеха Вашего бизнеса и увеличения вашей прибыли! Мы делаем красивые и максимально эффектные сайты по доступным ценам уже много лет!
Комплексный подход это не просто продвижение сайта, это целый комплекс мероприятий, который определяется целями и задачами поставленными перед сайтом и организацией, которая за этим стоит. Время однобоких методов в продвижении сайтов уже прошло, конкуренция слишком высока, чтобы была возможность расслабиться и получать \ удерживать клиентов из Интернета, просто сделав сайт и не занимаясь им...
Мы оказываем полный комплекс услуг по сопровождению сайта: информационному и техническому обслуживанию и развитию Интернет сайтов.
Контекстная реклама - это эффективный инструмент в интернет маркетинге, целью которого является увеличение продаж. Главный плюс контекстной рекламы заключается в том, что она работает избирательно.