Тестовые задания для собеседования на соображалку

Есть таблица пользователей и их пол, каждый пользователь принадлежит к какой-то группе.

CREATE TABLE `users` (
   `id` int(11) NOT NULL AUTO_INCREMENT,
   `gender` enum('m','w') DEFAULT NULL,
   `group_id` int(11) NOT NULL DEFAULT '0',
   PRIMARY KEY (`id`)
)

INSERT INTO `users` VALUES (1,1,'m'),(2,1,'m'),(3,1,'w'),(4,2,'m'),(5,2,'w'),(6,3,'m');

Необходимо найти группы исключая группу 3, в которых мужчин больше чем женщин. И правильный ответ:

SELECT group_id,
count(IF (gender='m', 1, NULL)) as m,
count(IF (gender='w', 1, NULL)) as w
FROM users
WHERE group_id <> 3
GROUP BY group_id
HAVING m > w

Удачки.

Оцени публикацию:
  • 3,14
Оценили: 3


Комментарии посетителей:

  • Вы уверены, что правильный запрос на 1 вопрос будет именно таким?
    У меня, с другими данными он не прошёл. Более того, а что если будут новости без категорий вообще?
    Вот мой запрос:
    SELECT news.id, COUNT(DISTINCT nc1.cat_id) nc1_count, COUNT(DISTINCT nc2.cat_id) nc2_count
    FROM news
    LEFT JOIN news_cat nc1 ON news.id = nc1.news_id
    LEFT JOIN news_cat nc2 ON news.id = nc2.news_id AND nc2.cat_id <> 5
    GROUP BY news.id
    HAVING nc1_count = nc2_count
    24 сентября 2014, 19:59 коммент полезен : 0 # Илья (гость)
    • Наверное не хватает условия: новостей без категорий не бывает
      17 июля 2015, 17:51 коммент полезен : 0 # Lebnik
  • По первому вопросу - оба варианта (в теле и в комментарии) не верные. Думайте.
    18 мая 2015, 15:35 коммент полезен : 0 # Дмитрий (гость)
    • уже подумал, может подскажите правильный ответ?:)
      17 июля 2015, 17:52 коммент полезен : 0 # Lebnik (гость)

Предложения и пожелания:

 

youtube.com/watch?v=7hFivbgIEqk

При полном или частичном использовании материалов данного сайта, ссылка на сайт "yapro.ru" обязательна как на источник информации.
Автоматический импорт материалов и информации с сайта запрещен.
Copyrights © 2007 - 2019 YaPro.Ru

Лебеденко Николай Николаевич
Ошибка в тексте? Выделите её мышкой и нажмите: Ctrl + Enter