Курсы по программированию

Формула программиста

основатель — Волосатов Евгений Витольдович
Поздравляю с 1 сентября! Система начисления Байтов работает.

Доска объявлений / Работаем над ошибками - YII2 в помощь

  • На этом уроке мы разберемся, как работать над ошибками и читать сигналы дебаггера YII2
  • Дата отправки отчёта: 22 августа 2019 г.
  • Задание выполнено: за 37 мин.
  • Чему научился: Ну это вообще то урок про меня. Я искал эту ошибку "вечность" - скорей из-за того что не знаю английского языка :-))
  • Оценка видео-уроку:
Отчёт от 21714 за Доска объявлений / Работаем над ошибками - YII2 в помощь


Отчёт от 21714 за Доска объявлений / Работаем над ошибками - YII2 в помощь




Оцени работу

 
Сохранить страницу:

17947. --
Dmitry Sinitsin
Dmitry Sinitsin
ответить
→  grom518  # Доска объявлений / Работаем над ошибками - YII2 в помощь / 2019-08-22 17:15

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


791. --
Валерий Жданов
Валерий Жданов
ответить
→  grom518  # Доска объявлений / Работаем над ошибками - YII2 в помощь / 2019-08-22 19:40

В данном случае знание инглиша вообще не причем. Вся ошибка в неточном написании параметра, который yii2 посчитал как две разных переменных (то же самое было бы и с использованием русского языка, если бы grom518 написал в одном месте gorOd, а в другом - gorAd).

Но с комментарием Дмитрия про язык Шекспира согласен)))


  • Отчёт оценивали:
    17947Dmitry Sinitsin+1   791Валерий Жданов+1   17425ser2018+1   11019Trira+1   8275Tekashnik+1   18783Andrew+1   14981DimanDOS+1   22133ES35+1   7119Новопашин Владимир+1   2912Игорь+1  

Начинаем практику по языку C#





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

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.


Научился: Научился ловить некоторые ошибки с помощью встроенного дебагера. Отличный урок. Его бы в начало курса!
Трудности: Повторить ошибки, приведенные в уроке - большого ума не надо. Я попробовал сделать ошибку другого типа: в файле ...\views\user\adduser.php строке 'adduser-Form']); ?> заменил 'adduser-Form' на 'addser-Form' При этом система не обнаружила ошибки и приняла нового пользователя. Как это можно объяснить?



Научился: Внес ошибку в метод getBulletins в контроллере BulletinsController. Вместо поиска по user_id указал userid. В результате на первом скриншоте yii сообщает о неизвестном столбце userid в блоке where. Yii сообщает запрос, который вывел ошибку SELECT * FROM `bulletins` WHERE (`userid`=1) AND (`status`='wait'). Если знать структуру таблицы bulletins, то можно понять, что ошибка в опечатке userid и надо заменить на правильное user_id. Теперь надо найти место в коде, которое вызвало эту ошибку. Далее ниже в пункте 1 показано место генерации исключения это файл Schema.php. Это внутренний файл Yii, который я не редактировал, значит ошибка возникла где-то ранее в цепочке вызовов функций. Далее ниже идет цепочка из 6 вызовов функций, которые так же как и 1 являются системными. Пролистав ниже можно найти пункт 7 (на втором скриншоте), в котором показан файл BulletinsController. Этот файл в отличие от первых 6 был создан мной, поэтому ошибка вполне может быть здесь. В 7 пункте Yii указывает на sql-запрос, в котором в блоке where идет обращение к userid. Ранее yii сообщал, что не может найти поле userid. Исправив userid на user_id ошибка исчезла.