Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
 Аватар для Aumi
20 / 36 / 14
Регистрация: 08.10.2015
Сообщений: 406

Проверка наличия записи

01.11.2018, 10:09. Показов 3137. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте,

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

Sclad:
id
111
222
888

Info:
idName
111 aaa
222 bbb
333 ccc

Мне нужен такой запрос, если данный id есть на складе, то в инфо писалось "да", иначе "нет"

У меня есть такое решение. Скажите, есть ли еще варианты решения, которые были бы лучше?

SQL
1
2
3
4
  SELECT [id],[Name],
 (CASE WHEN COUNT(s.id)>0 THEN 'да' ELSE 'нет' END) AS [Наличие]
 FROM Info a LEFT JOIN Sclad s ON a.id=s.id
  GROUP BY [id],[Name]
Вывод:
idName Наличие
111 aaa да
222 bbb да
333 ccc нет
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.11.2018, 10:09
Ответы с готовыми решениями:

Проверка на одинаковые записи в БД
У меня на сайте происходит авторизация через вк, и id от ВК записывается в БД, но при каждом входе одного и того же юзера записывается тот...

Простейшие триггеры, проверка уникальности записи
Здравствуйте, я не очень силён в SQL/T-SQL, поэтому нужна помощь. Создал я БД - Авиация, в которой есть таблицы Рейсы ( PK) и Билеты ( FK...

проверка наличия записи
Здравствуйте!Снова уповаю на вашу помощь...Получилось так что в бд один и тот же тип данных вносят несколько пользователей, отсюда вытекает...

9
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
01.11.2018, 10:21
T-SQL
1
2
3
4
SELECT
 [id],[Name],
 CASE WHEN exists(select * from Sklad where id = a.id) THEN 'да' ELSE 'нет' END AS [Наличие]
FROM Info a;
1
 Аватар для Aumi
20 / 36 / 14
Регистрация: 08.10.2015
Сообщений: 406
01.11.2018, 10:27  [ТС]
invm, скажите пожалуйста, ваше решение будет быстрее выполняться моего?
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
01.11.2018, 10:37
Должно быстрее
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
01.11.2018, 10:52
Цитата Сообщение от invm Посмотреть сообщение
T-SQL
1
2
3
4
SELECT
 [id],[Name],
 CASE WHEN exists(select * from Sklad where id = a.id) THEN 'да' ELSE 'нет' END AS [Наличие]
FROM Info a;
T-SQL
1
2
3
4
SELECT
 a.[id],a.[Name],
 [Наличие]=ISNULL((SELECT 'да' FROM Sklad WHERE id=a.id),'нет')  
FROM Info a;
1
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
01.11.2018, 11:23
iap, опустим неработоспособность вашего способа, если в Sklad более одной строки на id...

Ваш вариант даст в плане выполнения NL, а в варианте с exists могут быть и MERGE, и HASH.
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
01.11.2018, 11:40
Цитата Сообщение от invm Посмотреть сообщение
iap, опустим неработоспособность вашего способа, если в Sklad более одной строки на id...
Ваш вариант даст в плане выполнения NL, а в варианте с exists могут быть и MERGE, и HASH.
Очень быстро вспомнил об этом, но лень было сразу исправлять...
Ничего против EXISTS() не имею. Более того, это мой любимый предикат!
T-SQL
1
2
3
4
SELECT
 a.[id],a.[Name],
 [Наличие]=ISNULL((SELECT TOP(1) 'да' FROM Sklad WHERE id=a.id),'нет')
FROM Info a;
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
01.11.2018, 11:51
iap, с top (1) тоже NL
0
 Аватар для Aumi
20 / 36 / 14
Регистрация: 08.10.2015
Сообщений: 406
01.11.2018, 12:31  [ТС]
Цитата Сообщение от invm Посмотреть сообщение
если в Sklad более одной строки на id...
Я не совсем поняла. Если Sclad будет состоять из нескольких столбцов?
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
01.11.2018, 15:53
Цитата Сообщение от Aumi Посмотреть сообщение
Я не совсем поняла. Если Sclad будет состоять из нескольких столбцов?
"строка" и "столбец" есть разница?

а вообще имелось ввиду, что id может и не быть уникальным, и вернется более одной записи
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.11.2018, 15:53
Помогаю со студенческими работами здесь

Проверка наличия записи в таблице
Всем доброго времени суток, есть проблемка. Есть форма регистрации, проверка на логин есть, а вот на email нету, помогите сделать: Код:...

Проверка наличия записи в реестре
здравствуйте, такая проблема есть 2 раздела HKLM\SYSTEM\0000 и HKLM\SYSTEM\0001 в них есть параметр "Param" который находиться...

Проверка наличия записи в реестре
Для автозапуска программы внёс в реестр: Dim Start As Microsoft.Win32.RegistryKey =...

Проверка наличия записи в таблице и ее обновление
Здравствуйте. У меня проблема. Как сделать проверку Если в таблице user_item с char_id=$top есть item_type='4037' то он делает апдейт...

Проверка наличия записи с определенным значением в поле рекордсета
Здравствуйте. Возникла такая задача: Нужно проверить, есть ли в поле ADO-рекордсета запись с заданным значением? и чтобы...


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

Или воспользуйтесь поиском по форуму:
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 и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru