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

Автор: Aport Суббота, Январь 31st, 2015 Нет комментариев

Рубрика: MySQL

Задача 1

Есть новость и категория новости. Новость может принадлежать нескольким категориям. 3нф. Нужно выбрать все новости, которые не принадлежат категории с cat_id=5 (если новость принадлежит двум категориям, например, 2 и 5 — ее не выбираем). Сделайте это одним запросом с использованием join-ов.

Хорошо, чтобы программист сам составил схему таблиц. А проверить его ответ можно по схеме:

CREATE TABLE `cat` (
`id` int(11) NOT NULL,
PRIMARY KEY (`id`)
);

INSERT INTO `cat` VALUES (1),(2),(3),(4),(5);

CREATE TABLE `news` (
`id` int(11) NOT NULL,
`name` varchar(45) DEFAULT NULL,
PRIMARY KEY (`id`)
);

INSERT INTO `news` VALUES (6,’6y’),(7,’7u’),(8,’8i’),(9,’9o’),(10,’10p’);

CREATE TABLE `news_cat` (
`news_id` int(11) NOT NULL,
`cat_id` int(11) NOT NULL
);

INSERT INTO `news_cat` VALUES (6,1),(6,2),(7,3),(8,4),(10,5);

И правильный запрос:

select n.*, count(*) AS h
from news_cat AS nc
left join cat AS c ON c.id = nc.cat_id
left join news AS n ON n.id = nc.news_id
where nc.cat_id <> 5
group by nc.news_id
having h <> 2

Задача 2

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

CREATE TABLE `users` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`group_id` int(11) NOT NULL DEFAULT ’0′,
`gender` enum(‘m’,'w’) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB

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

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

SELECT *, count(*) AS x,
count(IF (gender=’m', 1, NULL)) as m,
count(IF (gender=’w', 1, NULL)) as w
FROM users
GROUP BY group_id
HAVING m > w

Удачки.

 

Источник: yapro.ru

Оставить комментарий

Чтобы оставлять комментарии Вы должны быть авторизованы.

Похожие посты