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

Как правильно составить запрос?

02.11.2014, 19:38. Показов 1596. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
БД 'Морской порт'
Таблица кораблей:
SQL
1
2
3
4
5
6
CREATE TABLE Ships (
id_ship INT NOT NULL PRIMARY KEY COMMENT 'Номер корабля',
name_ship CHAR(40) NOT NULL COMMENT 'Название корабля',
displacement INT NOT NULL COMMENT 'Вес корабля',
place CHAR(30) NOT NULL COMMENT 'Расположение',
id_captain INT NOT NULL COMMENT 'Номер капитана' FOREIGN KEY REFERENCES Captains (id_captain))
Таблица портов:
SQL
1
2
3
4
5
CREATE TABLE Sea_ports (
id_port INT NOT NULL PRIMARY KEY COMMENT 'Номер порта',
name_port CHAR(30) NOT NULL COMMENT 'Название порта',
counrty CHAR(30) NOT NULL COMMENT 'Месторасположение',
type_port CHAR(30) NOT NULL COMMENT 'Тип порта')
Таблица рабочих дней:
SQL
1
2
3
4
5
6
7
CREATE TABLE Working_Days (
id_day INT NOT NULL PRIMARY KEY COMMENT 'Номер рабочего дня',
input_day DATETIME NOT NULL COMMENT 'Дата прихода',
output_day DATETIME NOT NULL COMMENT 'Дата выхода',
objective CHAR(40) NOT NULL COMMENT 'Цель',
id_ship INT NOT NULL FOREIGN KEY REFERENCES Ships(id_ship)
id_port INT NOT NULL FOREIGN KEY REFERENCES Sea_ports(id_port)
Корабль движется в определенный порт, все это отображается в таблице Working_days.
Помогите советом, как выполнить следующий запрос:
Миниатюры
Как правильно составить запрос?  
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.11.2014, 19:38
Ответы с готовыми решениями:

Как правильно составить запрос к базе данных?
Здравствуйте. Нужна помощь в составлении запроса к базе данных. Есть некоторая база данных в ней находятся таблицы. Есть одна...

Неполучается правильно составить запрос
Здравствуйте! я новичок в MS SQL, поэтому пришел к вам за помощью ув. форумчане. Если что не внятно написал прошу простить и...

Простой запрос. Помогите правильно составить.
Надо добавить столбец в таблицу Access (рус. верс). ALTER TABLE Adr ADD (name text(255)) не прокатывает. Спасибо.

7
0 / 0 / 0
Регистрация: 14.09.2014
Сообщений: 173
02.11.2014, 19:43  [ТС]
Вот мой вариант, неправильный:
SQL
1
2
SELECT DISTINCT sea_ports.country AS 'Страны' FROM sea_ports, working_days, ships
WHERE (working_days.objective <> 'Туризм') AND (working_days.id_ship = ships.id_ship) AND (working_days.id_port = sea_ports.id_port);
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
02.11.2014, 20:52
Это задача с sql-ex ?
0
0 / 0 / 0
Регистрация: 14.09.2014
Сообщений: 173
03.11.2014, 09:05  [ТС]
до этого момента даже не знал что это такое. Нет, не оттуда

Добавлено через 11 часов 25 минут
Подскажите, пожалуйста
0
311 / 271 / 118
Регистрация: 05.06.2013
Сообщений: 868
03.11.2014, 11:31
SQL
1
2
3
SELECT DISTINCT SP.counrty FROM Sea_ports SP
LEFT JOIN Working_Days WD ON SP.id_port = WD.id_port AND WD.objective = 'Туризм'
WHERE WD.id_port IS NULL
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
03.11.2014, 11:32
T-SQL
1
2
3
4
5
6
7
SELECT DISTINCT country
    FROM Sea_ports
    WHERE NOT EXISTS
        (SELECT *
            FROM Working_Days
            WHERE id_port = Sea_ports.id_port
                AND objective = 'Туризм')
0
0 / 0 / 0
Регистрация: 14.09.2014
Сообщений: 173
03.11.2014, 12:10  [ТС]
Jefe, kodv, подвох в том, что у каждого порта может быть несколько назначений, помимо туризма. Ваши запросы выкидывают строки с objective = 'Туризм', но по заданию должно исключать страну.
Пр.: У России есть два порта. Первый посетили с целью Туризм, второй с целью Ремонт. Нужно, чтобы не просто была исключена строка, нужно целиком удалить страну, показав, что такую страну посещают с целью Туризм.
Как такое сделать?
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
03.11.2014, 12:19
Лучший ответ Сообщение было отмечено Beezy как решение

Решение

T-SQL
1
2
3
4
5
6
7
8
9
 SELECT DISTINCT country
    FROM Sea_ports sp
    WHERE NOT EXISTS
        (SELECT *
            FROM Working_Days
                JOIN Sea_ports
                    ON Sea_ports.id_port =  Working_Days.id_port
                        AND Sea_ports.Country = sp.Country
            WHERE objective = 'Туризм')
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.11.2014, 12:19
Помогаю со студенческими работами здесь

Как правильно написать запрос
Привет, Пишу впервые сложный запрос (по крайней мере для меня) и так: Есть таблица КОД Имя Адрес Дата 123 Иван...

Как правильно построить запрос?
Собственно вся проблема продемонстрирована на прилагаемом рисунке. В некой таблице, существуют два поля, которые ссылаются на две...

Как правильно написать запрос
Очень нужна помощь с запросом. Есть товар 30767 для которого рассчитывается расчетная цена select top 1 @Rasch=...

Как правильно написать запрос с group by?
Выручайте! закончил работать над веб апликацией, застрял на последнм =( надо узнать сколько пользователей имеют записей в...

Как правильно написать рекурсивный запрос?
У меня есть такой запрос, который не хочет работать: CTE_month AS ( SELECT CAST(@StartDate AS DATE) AS dt UNION ALL SELECT...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru