PHP Интервью
41 subscribers
17 photos
1 video
8 files
34 links
Помогаем PHP-Джуниорам пройти собеседование и устроиться на работу.
Делимся о чем спрашивают на собеседованиях
Предварительное собеседование с автором канала
Советы как правильно составить резюме
Авторские статьи и видео-обзоры

Автор @fxdev
Download Telegram
MySQL. Темы для изучения перед интервью

Утилиты командной строки:
mysql
mysqldump

Информация о базах, таблицах, ключах и индексах:
use databaseName;
show databases;
show tables;
show tables like '%table%';
desc tableName;
show indexes from tableName;
show keys from tableName;
show create table tableName;

Манипуляция структурой и данными
create table newTable like oldTable;
alter table tableName ... ;
drop table tablename;
drop database databasename;
truncate table tableName;

Выборка данных SELECT
— Изучить простой SELECT
— Изучить SELECT с псевдонимами: SELECT column_id as 'id', column_name as 'name' FROM tableName as t;
— Изучить SELECT c LIMIT
— Изучить SELECT c WHERE
— Изучить SELECT c WHERE columnName in (SELECT value FROM tableName)
— Изучить SELECT c WHERE columnName is null or columnName is not null
— Изучить SELECT c WHERE 'LIKE' vs '=' (понимать разницу)
— Изучить SELECT c ORDER
— Изучить SELECT c ORDER и RAND()
— Изучить SELECT c GROUP
— Изучить SELECT c агрегирующими функциями count(), max(), min(), sum() и т.д.
— Изучить SELECT c подзапросами FROM (SELECT * FROM tableName)
— Внимательно изучить SELECT c DISTINCT
— Внимательно изучить SELECT c EXPLAIN. Данная команда требует особого внимания!
— Что такое filesort в EXPLAIN

Выборка данных через SELECT с JOIN
— Изучить обычный JOIN
— Изучить LEFT JOIN
— Изучить RIGHT JOIN
ВНИМАНИЕ: Важно четко понимать разницу между джойнами. Это любимый вопрос на собеседовании.

Вставка данных
— Изучить INSERT с перечислением полей
— Изучить INSERT без перечисления полей
— Изучить INSERT c IGNORE
— Изучить INSERT c SELECT
— Изучить множественный INSERT

Обновление данных
— Изучить простой UPDATE
— Изучить UPDATE с LIMIT и WHERE

Индексы
— Для каких типов полей можно создать индекс?
— Какова длина индекса?
— Что такое составной индекс?
— Что такое уникальный индекс?
— Для типа TEXT можно ли создать индекс?
— Как определить используется ли в запросе индекс?

Движки и форки
— Найти полный список движков в MySQL и изучить.
— Почитать про основные различия между MyISAM и InnoDB
— ВАЖНО: Четко понимать, что такое "транзакция" и "блокировка".
— Почитать про MariaDB и Percona Server

🚫 Если вы не знаете хотя бы половину того, что описано выше, то вам стоит не спешить с собеседованием и подтянуть свои знания.
🤔Как ни крути, но получить хороший опыт можно лишь с реального проекта. Вариантов тут не много, либо начать что-то делать для себя, либо найти проект на фрилансе и выполнить его бесплатно, либо устроиться на работу по вакансии PHP-Джуниор.

1⃣Вариант начать что-то делать для себя выглядит, как самый перспективный, но на деле самый сложный. Очень сложно, каждый день, заставлять себя делать работу, которая в итоге не будет вознаграждена, даже осознавая, что вознаграждение есть полученный опыт.

2⃣ Взять проект на фрилансе, тоже вариант, но есть риск испортить себе репутацию в самом начале карьеры, потому что задача может оказаться не по зубам.

3⃣ Остается последний, на мой взгляд достаточно надежный вариант, найти вакансию PHP-Джуниора. Весь фокус в том, что компания, которая берет к себе на работу Джуниора — прекрасно понимает все риски и готова инвестировать в вас, хоть иногда и требуя взамен некую расписку, что вы не убежите, как только чему-то научитесь. Дополнительным бонус будет наличие наставника, который поможет ознакомиться с текущим проектом и будет помогать с будущими задачами.


Из опубликованного ранее
Программирование — это не для каждого.

Как же много сейчас студентов приходят учить программирование только потому, что за него много платят, не задумываясь, что за этим скрывается. А скрывается за этим тяжкий труд и огромное количество часов практики. Чтобы наработать такое количество практики одной финансовой мотивации не достаточно. Даже если вам понравилось программировать это всё равно не показатель, что вы добьетесь успеха и выйдите на желаемый уровень оплаты.

Очень важно иметь предрасположенность к программированию. Этот термин я давно вынашивал у себя в голове, пытаясь расшифровать, что же кроется за «предрасположенностью» и в итоге, после прочтения некоторых книг, я сформулировал определение:

Предрасположенность к программированию — это ваш жизненный опыт, который вы получили еще до того, как начать печатать первую строку «Hello World». Это ваши страсти и ваши знания, которые были получены в школе или институте. И эти знания и опыт были сильно бизки к навыкам программиста.

Как вы относились к задачам из Математики? Любили разгадывать головоломки? Как часто вы попадали в ситуации в которых вам помогла логика? Вы любили разгадывать загадки? Может вы занимались чем-то интересным и практически неподвижным много часов подряд?

Задайте себе эти вопросы и подумайте над ответами. Если большинство ответов отрицательны то вам будет сложно набрать нужное количество часов практики, чтобы выйти на желаемый уровень и начать хорошо зарабатывать. Вероятно ваша предрасположенность направлена в сторону другой профессии и не стоит тратить время и силы.

Заметьте, все вопросы в прошедшем времени, потому что иначе вы можете обмануть самого себя, задавая их в настоящем.

🤔Хорошенько подумайте над этим.
Пароли должны остаться в прошлом 🔐

Подключение к удаленному серверу для его настройки или «деплоя» кода — это обычная повседневная практика программиста. Хранить или запоминать большое количество паролей от разных серверов не просто. В добавок есть риск, что пароль может быть похищен или скомпрометирован. Нередко новички работая в Windows сохраняют пароль в программе, а затем его похищает какой-нибудь троян и пиши пропало.

Что же делать?
Во-первых нужно отказаться, по возможности, от использования FTP. Это довольно старый протокол, разработанный еще в 70-е годы, а программы реализующие данный протокол часто бывают подвержены эксплоиту.

Есть отличная альтернатива sftp протокол, который работает на базе протокола ssh. Протокол ssh используется, в том числе, для удалённого управления сервером и его надежность на достаточно высоком уровне. Подключиться к серверу по ssh можно, как используя пароль, так и используя ключ доступа, о последнем методе я и хочу рассказать.

Ключи уже довольно давно используются в мире IT, как средство прохождения авторизации. Для начала работы с ключами, вам необходимо сгенерировать свою пару ключей: Публичный и Приватный. Команда для генерации
ssh-keygen
. Публичный ключ это по сути «замóк», который может открыть только тот приватный ключ, который был создан одновременно с публичным.

А дальше всё просто. Приватный ключ должен находиться на компьютере с которого происходит подключение, а публичный на сервере в файле
~/.ssh/authorized_keys
. Данный файл находится в домашней директории пользователя под которым вы планируете производить подключение. Установите публичный ключ на всех серверах, с которыми вы работаете и вам не придется запоминать пароли для подключения. Приватный ключ храните у себя и не показывайте никому. Имея доступ к серверу по ssh вы также можете подключиться к нему используя протокол sftp. А еще, используя ключ, очень удобно работать с GIT через протокол ssh.

Напоследок хотел бы рассказать, как я храню пароли для сайтов, которые посещаю. Есть такое расширение для хрома (и не только) LastPass. Его можно установить в любой браузер, а также на телефоне. Ваши данные, которые вы сохраняете на сервере LastPass шифруются мастер-паролем и даже если сервер LastPass будет взломан, без мастер-пароля злоумышленники не смогут добраться до ваших данных.

——
К чему приводят пароли на стикерах
👉 https://habr.com/ru/post/255509/
Всем доброго дня!

На следующей недели (с 15 по 20 февраля) провожу 3 бесплатных собеседования с целью узнать свой текущий уровень знаний и навыков. Все вопросы будут касаться PHP и web-программирования.

Желающие пишите мне в личку.
Аккаунт @fxDev
Не упускайте теорию 📚

Часто новички в программировании стараются больше практиковаться в кодинге, совершенно забывая про теорию. Даже если они читают книги, то стараются искать иллюстрации кода, чтобы сразу воспользоваться новыми знаниями на практике.

Так зачем же теория программисту, если ему только и надо, что код писáть

Изучение теории расширяет наш кругозор. Это крайне важно для проектирования будущих проектов. Если программист не в состоянии спроектировать свой проект, то ему и кодить будет нечего.

Конечно, исключением являются крупные IT компании, где проектированием занимаются умные люди, которые уже перечитали массу книг о различных технологиях и методах проектирования. Но мы с вами едва ли попадем к ним работать на первых порах и потому, должны уметь самостоятельно проектировать.

Это совсем не означает, что нужно удариться в чтение и перестать кодить.

Я лишь призываю вас не упускать теорию, ведь на собеседовании первый этап, это как правило теория и лишь пройдя её вы сможете блеснуть перед интервьюером своим прекрасным кодом!

--
Сборник задач https://justcoding.ru/
Числовой палиндром.

Палиндро́м — число, буквосочетание, слово или текст, одинаково читающееся в обоих направлениях.

Примеры числовых палиндромов:
— 3993
— 170071
— 955559

Условие задачи

Вам дадут 2 числа в качестве аргументов: (number, s).

Напишите функцию, которая возвращает массив из числа s палиндромов, которые идут после number. Если number - это сам палиндром, он должен быть включен в число.

Если один из входных параметров не является целым числом или меньше 0, верните «не действительно».

Ссылка на задачу 👇
https://justcoding.ru/solve-task?id=51


Завтра опубликую различные варианты решения данной задачи.
Варианты решения задачи
Задача одна, но решений может быть много и разных!
Всем доброго дня!

На следующей недели (с 1 по 5 марта) провожу 3 бесплатных собеседования с целью узнать свой текущий уровень знаний и навыков. Кто проходил ранее и за это время смог подтянуть свои знания, тоже могут написать. Все вопросы будут касаться PHP и web-программирования.

Желающие пишите мне в личку.
Аккаунт @fxDev
Запись закрыта.
Мест больше нет.
Forwarded from Tester of QA
С первым днём весны!
Задача #42 — Заставь мертвую рыбу плавать

Напишите простой парсер, который будет анализировать и запускать Deadfish.

У Deadfish есть 4 команды, каждая длиной 1 символ:

i увеличивает значение (изначально 0)
d уменьшает значение
s возводит значение в квадрат
o выводит значение в возвращаемый массив

Неверные символы следует игнорировать.
parse("iisiodso") => [ 5, 36 ]

https://justcoding.ru/solve-task?id=42

——
Завтра опубликую различные варианты решений.
Различные решения задачи
Собеседование программистов

На следующей недели (с 9 по 12 марта) провожу 3 бесплатных собеседования с целью узнать ваш текущий уровень знаний и навыков. Все вопросы будут касаться PHP и web-программирования.

Кто проходил ранее и за это время смог подтянуть свои знания, тоже могут записываться.

Желающие пишите мне в личку.
Аккаунт @fxDev
Ошибки начинающего.

Я давно замечаю за новичками одну интересную особенность. Они страсть как любят впихнуть невпихуемое. Стараются в одну строку вставить сразу максимальное количество команд, считая это высшей степенью профессионализма. Вот только профи так не делают, ведь это сильно губит возможность читать код и как следствие его сопровождать.

Подумайте сами, код как боксерский титул, сложность не в том, чтобы его завоевать, а в том, чтобы его удержать. Так же и с кодом, сложность не в том, чтобы его написать, а в том, чтобы его сопровождать и дорабатывать, добавляя всякие фишечки.

Перестаньте показывать на сколько вы круты, умением в одну строку впихнуть десять функций, покажите, что вы умеете создавать по-настоящему простой и читабельный код, это ценится гораздо выше!