Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
9 / 8 / 1
Регистрация: 18.05.2009
Сообщений: 40

Тестовое задание

31.08.2021, 19:36. Показов 2200. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
С заданием я почти не справился, просто просили разобраться с этим, не влияет ни на что. Хотелось бы для себя понять всё )))


Oracle 11 SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
-- Задание 1
-- Вывести пользователей по которым нет событий аудита.
 
-- Задание 2
-- Вывести email и количество событий аудита по каждому пользователю.
 
-- Задание 3
-- Вывести email тех пользователей которые меняли свой пароль более 3 раз.
 
-- Задание 4
-- Вывести email тех пользователей которые меняли свой пароль более 3 раз за последние 30 дней
 
CREATE TABLE users (
user_id INT,
email text,
PRIMARY KEY (user_id)
);
 
INSERT INTO users (user_id, email) VALUES (1, '1@test.ru');
INSERT INTO users (user_id, email) VALUES (2, '2@test.ru');
INSERT INTO users (user_id, email) VALUES (3, '3@test.ru');
 
CREATE TABLE AUDIT (
user_id INT REFERENCES users(user_id),
action_date DATE,
action_type text
);
 
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '31 day', 'login');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '32 day', 'passchange');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '32 day', 'login');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '20 day', 'passchange');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '19 day', 'login');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '10 day', 'passchange');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '9 day', 'login');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '5 day', 'passchange');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (1, NOW() - INTERVAL '4 day', 'login');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (2, NOW() - INTERVAL '31 day', 'login');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (2, NOW() - INTERVAL '32 day', 'passchange');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (2, NOW() - INTERVAL '20 day', 'passchange');
INSERT INTO AUDIT (user_id, action_date, action_type) VALUES (2, NOW() - INTERVAL '10 day', 'passchange');
Решение первой задачи:
Oracle 11 SQL
1
2
3
SELECT * FROM users u
LEFT JOIN AUDIT a ON u.user_id = a.user_id
WHERE a.user_id IS NULL;
Просто, для себя, хотелось бы понять, как решать остальное. не работал с SQL примерно лет 6-7 уже
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.08.2021, 19:36
Ответы с готовыми решениями:

Тестовое задание
Добрый день! Относительно недавно начал изучать SQL, подкинули тестовое задание (во вложении). Ума не приложу как его сделать....

Тестовое задание на PL/SQL
Здравствуйте. Дали тестовое задание на PL/SQl. Есть вопросы и моменты, которые я не могу понять. Проверить свой код мне негде. Так как...

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

1
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
01.09.2021, 08:45
Лучший ответ Сообщение было отмечено maslanin как решение

Решение

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
SELECT u.email,COUNT(a.user_id)
  FROM users u LEFT JOIN AUDIT a ON a.user_id=u.user_id
  GROUP BY u.user_id,u.email
 
SELECT u.email
  FROM users u JOIN AUDIT a ON a.user_id=u.user_id AND a.action_type='passchange'
  GROUP BY u.user_id,u.email
  HAVING COUNT(a.user_id)>3
 
SELECT u.email
  FROM users u JOIN AUDIT a ON a.user_id=u.user_id AND a.action_type='passchange' AND NOW()-a.action_date<=INTERVAL '30 day'
  GROUP BY u.user_id,u.email
  HAVING COUNT(a.user_id)>3
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.09.2021, 08:45
Помогаю со студенческими работами здесь

Тестовое задание
Помогите пройти тест. Очень надо :) Введите пропущенный оператор в функцию вставки нового элемента в существующий список. 1. ...

Тестовое задание
private class Connect (){ public Device dev1 = new Device(); public Device dev2 = new Device(); puclic void Connect (){ for...

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

Тестовое задание
Возникла необходимость сделать вот такое задание. Create a configurable two-level cache (for caching Objects). Level 1 is memory,...

Тестовое задание
Дали тестовое задание, так как я его провалил, интересно сообразит ли кто то что вообще должен делать этот код и в чем тут ошибки? Потому...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru