Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 07.07.2016
Сообщений: 3

Выборка с игнорированием NULL

07.07.2016, 06:44. Показов 1140. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Недавно начал изучать MS SQL, наткнулся на задачу, второй день ломаю голову, не могу понять как правильно сделать выборку.

Есть две таблицы.

band

id; name

1; Metallica
2; Rolling Stones
3; Rammstein

song

id; band_id; title; frontman

1; 3; Reise Reise; Lindemann
2; 3; Mutter; Lindemann
3; 1; Unforgiven; Hetfield

Задача: написать запрос, выводящий список групп и количество их песен в базе, включая тех, у кого песен нет.

То есть выборка должна получиться вида:

Metallica; 1
Rolling Stones; null
Rammstein; 3
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.07.2016, 06:44
Ответы с готовыми решениями:

Выборка с Null и без
Имеется программа с набором полей, в которые пользователь вводит усовия отбора из одной таблицы. Наховём их "Код" и...

Хранимая процедура и выборка, где bit(boolean) поле равно NULL
В общем, не большой я мастер в хранимых процедурах, но вот пришлось браться за них. Имеется таблица, типа такой структуры: | поле1 | |...

Поиск по таблице с игнорированием Null параметров
Всем привет. У меня есть таблица patient, с именем, фамилией, датой рождения... Мне необходимо сделать поиск по имени фамилии и дате...

5
5985 / 4560 / 1095
Регистрация: 29.08.2013
Сообщений: 28,197
Записей в блоге: 3
07.07.2016, 08:46
так?
SQL
1
2
3
4
SELECT name.name, COUNT(*)
FROM name 
LEFT JOIN song ON name.id=song.band_id
GROUP BY name.name
а зачем у песни frontman?
0
0 / 0 / 0
Регистрация: 07.07.2016
Сообщений: 3
07.07.2016, 23:03  [ТС]
qwertehok,
Скрипт выводит
Metallica 1
Rammstein 2
Rolling Stones 1
, хотя в последнем должно быть NULL

PS в первом посте опечатался,

То есть выборка должна получиться вида:

Metallica; 1
Rolling Stones; null
Rammstein; 3


Должно получиться Rammstein; 2
0
5985 / 4560 / 1095
Регистрация: 29.08.2013
Сообщений: 28,197
Записей в блоге: 3
07.07.2016, 23:08
попробуйте count(song.band_id)
0
0 / 0 / 0
Регистрация: 07.07.2016
Сообщений: 3
07.07.2016, 23:13  [ТС]
qwertehok, во, спасибо, почти то, что нужно

Правда, по условию задачи должно получиться 1; null; 2, а выводится 1; 0; 2
0
5985 / 4560 / 1095
Регистрация: 29.08.2013
Сообщений: 28,197
Записей в блоге: 3
08.07.2016, 09:39
Цитата Сообщение от asmoday47 Посмотреть сообщение
Правда, по условию задачи должно получиться 1; null; 2
Цитата Сообщение от asmoday47 Посмотреть сообщение
Задача: написать запрос, выводящий список групп и количество их песен в базе, включая тех, у кого песен нет
вы противоречите задаче, в которой сказано вывести КОЛИЧЕСТВО
NULL это не количество поскольку NULL<>0
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.07.2016, 09:39
Помогаю со студенческими работами здесь

Выборка из таблицы с NULL
Есть таблица svarka из которой нужно выбрать содержание столбца name при условии что сумма столбцов C и S, P этой же таблицы больше 5....

Почему не работает условная выборка с условием !=NULL ?
Добрых суток! Возник такой вопрос. Есть колонки id name +------+------+ | id | name | +------+------+ | 1 | Ivan | ...

Выборка из таблиц не выводит строки в которых значение null
Подскажите пожалуйста, пол ночи голову ломал и опять ломаю..... Есть мультизапрос в базу $result = pg_query( &quot;SELECT id_zayavki,...

Выборка данных из базы, request.getAttribute возвращает null
выборка данных из базы, хочу передать на jsp страницу и вывести, но при передаче request.getAttribute возвращает null сервлет ...

Выборка уникального значения, либо (если оно НЕ уникально) - то с NULL-левым полем
Всем привет. Есть таблица: CREATE TABLE tbl ( id INTEGER PRIMARY KEY, title varchar(40) NOT NULL, fld ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru