SQL | Подзапрос с EXISTS
Например выберем всех клиентов, которые совершили покупки до конца зимы:
Например выберем всех клиентов, которые совершили покупки до конца зимы:
select id, company_nameОператор EXISTS используется для проверки существования любой записи в подзапросе. Если подзапрос возвращает одну или несколько записей, то возвращается true. Обычно EXISTS используется в зависимых (коррелирующих) подзапросах.
from client
where exists (select *
from purchase
where client.id = purchase.client_id
where date > '2020-28-02')
👍1
Node.js | Streams
Стрим — это концепция, c помощью которой можно обрабатывать данные небольшими частями, что позволяет задействовать небольшой объем оперативной памяти.
Например нужно записать "тяжелый файл"
Модуль fs.createReadStream может предоставить нам Stream
В статье вы найдете больше информации и где еще применяют потоки.
Стрим — это концепция, c помощью которой можно обрабатывать данные небольшими частями, что позволяет задействовать небольшой объем оперативной памяти.
Например нужно записать "тяжелый файл"
const fs = require('fs');
const file = fs.createWriteStream('./big.file');
for(let i=0; i<= 1e6; i++) {
file.write('Длинный текст\n');
}
file.end();
Запуская сервер мы получим нагрузку на оперативную память ~ 400 MBМодуль fs.createReadStream может предоставить нам Stream
const fs = require('fs');
const server = require('http').createServer();
server.on('request', (req, res) => {
const src = fs.createReadStream('./big.file');
src.pipe(res);
});
server.listen(8000);
Когда клиент запросит этот файл, мы транслируем его по частям, что означает, что мы вообще не буферизуем его в памяти. Использование памяти снизилось до 25 МБ.В статье вы найдете больше информации и где еще применяют потоки.
Кто такой Deno?
Deno – это новая runtime-среда для JavaScript и TypeScript от создателя Node.js. Инструмент построен на V8 (JavaScript-движок ), Rust (производительный и безопасный язык) и Tokio (асинхронный рантайм для Rust).
Преимущества
- Модули Deno могут быть размещены в любом месте ( локально кэшируются, не используется "package.json" )
- Безопасность ( не имеет открытого доступа к файловым или сетевым ресурсам по умолчанию)
- Встроенный TypeScript
- Тестирование ( в ядре )
- Форматирование кода
- Дебаг
- Compile/Bundle
- Deno HTTP server смогло обработать 25 тысяч запросов в секунду с максимальной задержкой в 1.3 миллисекунд. В Node.js аналогичное приложение обработало 34 тысячи запросов в секунду, но задержки колебались от 2 и 300 миллисекунд
- Все скрипты приложения могут быть объединены в один JavaScript файл
Deno имеет все шансы стать более продуманной средой выполнения Javanoscript, чем Node.js.
Deno – это новая runtime-среда для JavaScript и TypeScript от создателя Node.js. Инструмент построен на V8 (JavaScript-движок ), Rust (производительный и безопасный язык) и Tokio (асинхронный рантайм для Rust).
Преимущества
- Модули Deno могут быть размещены в любом месте ( локально кэшируются, не используется "package.json" )
- Безопасность ( не имеет открытого доступа к файловым или сетевым ресурсам по умолчанию)
- Встроенный TypeScript
- Тестирование ( в ядре )
- Форматирование кода
- Дебаг
- Compile/Bundle
- Deno HTTP server смогло обработать 25 тысяч запросов в секунду с максимальной задержкой в 1.3 миллисекунд. В Node.js аналогичное приложение обработало 34 тысячи запросов в секунду, но задержки колебались от 2 и 300 миллисекунд
- Все скрипты приложения могут быть объединены в один JavaScript файл
Deno имеет все шансы стать более продуманной средой выполнения Javanoscript, чем Node.js.
This media is not supported in your browser
VIEW IN TELEGRAM
CSS | Плавная прокрутка
Раньше, для оснащения страницы плавной прокруткой, требовалось задействовать несколько строк JS-кода. А теперь эта задача может быть решена исключительно средствами CSS
Раньше, для оснащения страницы плавной прокруткой, требовалось задействовать несколько строк JS-кода. А теперь эта задача может быть решена исключительно средствами CSS
html {
scroll-behavior: smooth;
}
После этого кода все якорные ссылки на странице будут прокручиваться плавно.Его пока не поддерживают Edge, IE и Safari (настольная и мобильная версии)Продолжите SQL запрос, что бы выбрать всех сотрудников начинающихся с буквы 'М' и заканчивающихся на 'А'
SELECT * FROM EMPLOYEES WHERE ...
SELECT * FROM EMPLOYEES WHERE ...
Anonymous Quiz
22%
EmpName like '/M/*А'
52%
EmpName like 'M%А'
9%
EmpName like 'M_А'
17%
EmpName like '%M%A'
This media is not supported in your browser
VIEW IN TELEGRAM
CSS | line-clamp
Свойство CSS -webkit-line-clamp позволяет ограничить содержимое контейнера блока указанным количеством строк
Нам, чтобы им пользоваться, надо прибегнуть к старой реализации flexbox, применив свойства display: -webkit-box и -webkit-box-orient: vertical.
Свойство CSS -webkit-line-clamp позволяет ограничить содержимое контейнера блока указанным количеством строк
Нам, чтобы им пользоваться, надо прибегнуть к старой реализации flexbox, применив свойства display: -webkit-box и -webkit-box-orient: vertical.
.card-denoscription {
overflow: hidden;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 3;
}
Описание карточки отобразит только 3 строкиJavaScript | async и defer
Если скрипт – внешний, то пока браузер не выполнит его, он не покажет часть страницы под ним.
Defer — сработает, когда весь HTML-документ будет обработан браузером. Также используют, когда нужно выполнить скрипты в строгом порядке
Если скрипт – внешний, то пока браузер не выполнит его, он не покажет часть страницы под ним.
<head>Чтобы этого избежать, JavaScript предоставляет нам две техники, известные как async и defer. Вы можете просто добавлять эти атрибуты к тегам
<noscript src="big.js"></noscript>
</head>
<body>
Этот текст не будет показан, пока браузер не выполнит big.js.
</body>
<noscript>.
Async — это когда вы говорите браузеру загружать скрипт, не затрагивая рендеринг. То есть, браузер не останавливает обработку страницы, а спокойно работает дальше. Когда скрипт будет загружен – он выполнится.Defer — сработает, когда весь HTML-документ будет обработан браузером. Также используют, когда нужно выполнить скрипты в строгом порядке
<noscript src="1.js" defer></noscript>Первым сработает всегда 1.js, а скрипт 2.js, даже если загрузился раньше, будет его ждать.
<noscript src="2.js" defer></noscript>
SQL | JOIN
Оператор языка SQL JOIN предназначен для соединения двух или более таблиц базы данных по совпадающему условию.
Выведем все голы, забитые в матче Россия-Чехия
Получим таблицу со всеми игроками, которые забили в этом матче с временем гола
———————————
|player | gtime |
———————————
|Alan Dzagoev | 39 |
Оператор языка SQL JOIN предназначен для соединения двух или более таблиц базы данных по совпадающему условию.
Выведем все голы, забитые в матче Россия-Чехия
SELECT player, gtimeОператор ON представляет одно или несколько условий JOIN.
FROM game JOIN goal ON matchid = id
WHERE (team1='RUS' AND team2='CZE')
Получим таблицу со всеми игроками, которые забили в этом матче с временем гола
———————————
|player | gtime |
———————————
|Alan Dzagoev | 39 |
This media is not supported in your browser
VIEW IN TELEGRAM
CSS | Random
Нестандартная реализация генерации случайного числа на чистом CSS без строчки JS.
Автор использовал :
Нестандартная реализация генерации случайного числа на чистом CSS без строчки JS.
Автор использовал :
@keyframesНа видео реализовано для большего понимания задумки, в оригинале анимация ускорена и получается эффект рандома.
z-index
:checked
🔥 Для тех кто ищет первую работу в IT
Работодатели платят хорошую ЗП, но не берут на себя обучение кадров. Их можно понять - бизнесу надо решать задачи прямо сейчас
Чтобы избежать боли поиска первой работы - возьмите обучение на себя
В Skillbox можно пройти обучение с гарантированным трудоустройством:
Frontend разработчик - 2750р / мес
* Fullstack разработчик - 2919р / мес
* Веб-разработчик PRO - 4083р / мес
* - первый платеж через 6 месяцев
Работодатели платят хорошую ЗП, но не берут на себя обучение кадров. Их можно понять - бизнесу надо решать задачи прямо сейчас
Чтобы избежать боли поиска первой работы - возьмите обучение на себя
В Skillbox можно пройти обучение с гарантированным трудоустройством:
Frontend разработчик - 2750р / мес
* Fullstack разработчик - 2919р / мес
* Веб-разработчик PRO - 4083р / мес
* - первый платеж через 6 месяцев
JSON.parse() и JSON.stringify()
нужны для преобразования json строки в объект и наоборот
Например, нам нужно сохранить данные в localStorage:
второй пример - полное клонирование объекта с преобразованием, метод JSON.parse принимает колбэк, который позволяет изменить результат парсинга
нужны для преобразования json строки в объект и наоборот
Например, нам нужно сохранить данные в localStorage:
const object = {id: 1};
const string = JSON.stringify(object);
localStorage.setItem(key, string);
const data = localStorage.getItem(key);
const retrieved = JSON.parse(string);
// retrieved содержит объект {id: 1}
второй пример - полное клонирование объекта с преобразованием, метод JSON.parse принимает колбэк, который позволяет изменить результат парсинга
const userStr = JSON.stringify({
id: 1,
name: 'John',
friends: [
{id: 2, name: 'Maria'},
{id: 3, name: 'Peter'}
]
});
const clone = JSON.parse(userStr,
(key, value) => {
if (typeof value === 'string') {
return value.toUpperCase();
}
return value;
});
console.log(clone);
// {
// id: 1,
// name: "JOHN",
// friends: [
// {id: 2, name: "MARIA"},
// {id: 3, name: "PETER"}
// ]
// }GIT | Основные команды
- git init - создает в текущем каталоге новый подкаталог с именем .git, создает git - репозиторий.
- git status - статус файлов, любых изменений.
- git add имя_файла - начинает отслеживать введенный файл.
- git add . - для отслеживания всех новых файлов текущего локального репозитория.
- git diff --cached - для просмотра что войдёт в следующий коммит.
- git commit -m "name commit" - фиксация изменений, создание коммита.
- git checkout master - отменит последние коммиты.
- git reset HEAD - очищает буферную зону от изменений, которые мы только что проиндексировали.
- git remote add origin - связывается с вашим репозиторием на GitHub, добавьте ссылку на ваш гит-репозиторий в конце.
- git push -u origin master - для размещения локального репозитория на сервере GitHub (или внесения изменений).
- git init - создает в текущем каталоге новый подкаталог с именем .git, создает git - репозиторий.
- git status - статус файлов, любых изменений.
- git add имя_файла - начинает отслеживать введенный файл.
- git add . - для отслеживания всех новых файлов текущего локального репозитория.
- git diff --cached - для просмотра что войдёт в следующий коммит.
- git commit -m "name commit" - фиксация изменений, создание коммита.
- git checkout master - отменит последние коммиты.
- git reset HEAD - очищает буферную зону от изменений, которые мы только что проиндексировали.
- git remote add origin - связывается с вашим репозиторием на GitHub, добавьте ссылку на ваш гит-репозиторий в конце.
- git push -u origin master - для размещения локального репозитория на сервере GitHub (или внесения изменений).
Какой цвет будет при наведении на ссылку после ее посещения?
Anonymous Quiz
37%
Red
4%
Green
10%
Yellow
49%
Lightblue
JS | Копирование объектов
1.
1.
function copy(mainObj) {
let objCopy = {}; // objCopy будет хранить копию mainObj
let key;
// копирует каждое свойство objCopy
for (key in mainObj) {
objCopy[key] = mainObj[key];
}
return objCopy;
}
2. let objCopy = Object.assign({}, obj);
3. let newObj = JSON.parse(JSON.stringify(obj));
4. let newObj = { ...obj };
У каждого из этого метода есть свои недостатки. В каких случаях применять каждый вы найдете в статье, где автор подробно разобрал каждый описанный метод.PHP | MAILРассмотрим простейший пример отправки письма PHP
<?phpВ начале мы определяем кому адресовано письмо, за это отвечает переменная $to, если же получателей несколько человек, то записываем через запятую адреса эл. почты. Переменные $subject и $message тема и текст письма соответственно.
$to = "<mail@example.com>, " ;
$to .= "mail2@example.com>";
$subject = "Заголовок письма";
$message = ' <p>Текст письма</p> </br> <b>1-ая строчка </b> </br><i>2-ая строчка </i> </br>';
$headers = "Дополнительный зоголовок";
mail($to, $subject, $message, $headers);
?>
Cейчас же так никто не делает, потому что почта стала более сложной вещью, поэтому используют библиотеки Swift Mailer или PHPMailer.
В статье присутствует инструкция по PHPMailer.
Как установить нулевую прозрачность элемента?
Anonymous Quiz
14%
opacity: none;
2%
opacity: hide;
16%
opacity: 0%;
68%
opacity: 0;