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

Удаление строк если некоторые ее данные не встречаются в другой таблице

08.12.2016, 00:12. Показов 7726. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
Есть таблица(TMP_1) в которой есть следующие столбцы:
дата(в коде DATEVRKV), артикул(ART) и модель(MOD)
нужно удалить все строки из этой таблицы при условии что дата будет меньше чем вводимый параметр и артикул, модель не будут встречаться в другой таблице(XWNPIO) которая представляет собой:
артикул(ARTI), модель(RIS).
Делаю так:
SQL
1
2
3
4
5
6
DELETE FROM TMP_1
    WHERE DATEVRKV < @DATE
    AND ART NOT IN(
        SELECT DISTINCT ARTI FROM XWNPIO ) 
    AND MOD NOT IN(
        SELECT DISTINCT RIS FROM XWNPIO )
Как я понимаю у меня оно срабатывает если:
1) @DATE больше чем DATEVRKV
2) ART нет в столбце ARTI таблицы XWNPIO
3) MOD нет в столбце RIS таблицы XWNPIO

А нужно чтобы срабатывало когда ARTI и RIS являются одной записью а не по отдельности. Важно, что бы не было именно связки этих значений в одной строке.
Помогите решить данный вопрос, извините если не смог правильно объясниться. За ранее очень благодарен.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.12.2016, 00:12
Ответы с готовыми решениями:

Перенос строк содержаших некоторые определенные слова в очень большой таблице на другой лист.
Добрый день! Надеюсь найду здесь помощь, потому что нужно сделать очень срочно. Поиск по форуму не помог. Есть большая таблица...

Удаление с таблицы, если нет id такого в другой таблице
Как составить запрос на проверку: если нет item_id в table2, то удалить в table1? Пишу такой запрос, но в результате всю таблицу...

Изменить запись в таблице, если данные берутся из другой таблицы и обе таблицы связаны
Есть две связанных таблицы. как через Update изменить запись в одной таблице ,если данные для поля этой таблицы берутся в другой.

2
119 / 111 / 47
Регистрация: 09.07.2013
Сообщений: 209
08.12.2016, 09:46
Лучший ответ Сообщение было отмечено dima77790 как решение

Решение

T-SQL
1
2
3
4
DELETE t
FROM TMP_1 t
LEFT JOIN XWNPIO x ON x.ARTI = t.ART AND x.RIS = t.MOD 
WHERE t.DATEVRKV < @DATE AND x.ARTI IS NULL
T-SQL
1
2
3
4
DELETE t
FROM TMP_1 t
WHERE t.DATEVRKV < @DATE 
      AND NOT EXISTS (SELECT * FROM XWNPIO x WHERE x.ARTI = t.ART AND x.RIS = t.MOD)
1
1 / 1 / 0
Регистрация: 06.10.2013
Сообщений: 12
08.12.2016, 13:43  [ТС]
Второй вариант нравится больше, спасибо огромное за ответ.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.12.2016, 13:43
Помогаю со студенческими работами здесь

Удаление строк в таблице
Здравствуйте есть макрос, который удаляет строки, если в столбце &quot;B&quot; шрифт ячейки красного цвета: Sub Макрос1() Dim sh As...

Удаление строк в таблице
Ещё раз всем привет! Каким образом можно удалять строки в исходной таблице? У меня есть Юзерформа, на которой расположены лейблы с...

Удаление строк в таблице
Требуется удалить из таблицы последние записи, количество которых находится в переменной $n_del: mysql_query(&quot;DELETE FROM...

Сцепка текста в ячейках, если совпадают значения в столбце А, удаление повторов имен, удаление лишних строк
Добрый день, подскажите, как решить задачу: Есть список организаций с контактами. Одна организация может быть представлена разным...

Если в ячейках столбца есть значения, перенести некоторые ячейки из строки на другой лист
Доброго времени суток, профессионалы и увлекающиеся) Очень надеюсь, что есть среди Вас неравнодушные, кто даст мне дельный совет, как...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru