Форум программистов
 
Контакты: о проблемах с регистрацией, почтой и по другим вопросам пишите сюда - alarforum@yandex.ru, проверяйте папку спам! Обязательно пройдите активизацию e-mail.

Вернуться   Форум программистов > Web > SQL, базы данных
Регистрация

Восстановить пароль
Повторная активизация e-mail


Ответ
 
Опции темы
Старый 13.06.2018, 19:16   #1
KBO
Форумчанин
 
Регистрация: 11.06.2010
Сообщений: 360
Репутация: 16
По умолчанию Вопрос по «merge», языка sql

Доброе время суток, форумчане.

Есть таблица устройств (DEVICE) в БД на FireBird (с полями «Наименование», «Тип», «Зав.номер» и т.д.) в которую из Excel экспортируются данные (устройства).
В БД добавилась вторая таблица «Человеко/часы» (NORM_HOURS), в которой нужно содержать только поля «Наименование» и «Тип» этих устройств ну и еще некоторые поля отличные от полей в DEVICE.
Т.е. в NORM_HOURS должны содержаться только уникальные устройства по оговоренным двум полям.

После экспорта устройств из файла в DEVICE, я делаю операцию «MERGE», для таблицы NORM_HOURS, чтоб эти устройства появились в NORM_HOURS.

Код:

merge into NORM_HOURS nh using DEVICES d on ((nh.NAME_DEVICE=d.NAME_DEVICE and nh.TYPE_DEVICE=d.TYPE_DEVICE))
   when matched then
   update set nh.NAME_DEVICE=d.NAME_DEVICE, nh.TYPE_DEVICE=d.TYPE_DEVICE
   when not matched then
   insert (nh.ID, nh.NAME_DEVICE, nh.TYPE_DEVICE, nh.USER_ID, nh.DEPARTMENT_ID, nh.TYPE_INPUT)
    values (GEN_ID(GEN_ID_NORM_HOURS, 1), d.NAME_DEVICE, d.TYPE_DEVICE, 1, 2, 3)

Вопросы по данной теме:
1. можно ли провести операцию «MERGE» делать не для всей таблицы DEVICE, а только для некоторых ее строк, скажем в которых d.PROPOSAL_ID=7 например?
2. если вдруг у меня d.TYPE_DEVICE пусто, а d.NAME_DEVICE заполнено, то такие строки продолжают вставляться, при повторном проведении скрипта (не смотря на то, что они в NORM_HOURS уже есть), можно ли как-нибудь избавиться от повторной вставки?
3. и правильно ли будет если я из скрипта уберу строки:

Код:

...when matched then update set nh.NAME_DEVICE=d.NAME_DEVICE, nh.TYPE_DEVICE=d.TYPE_DEVICE

? Просто я НЕ хочу обновлять те строки в NORM_HOURS, которые уже в ней есть
KBO вне форума   Ответить с цитированием
Ответ

Опции темы

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.

Быстрый переход

Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Вопрос насчет выбора языка. Saygolsz Общие вопросы C/C++ 4 09.11.2017 21:16
Тест на знание СУБД MS SQL и на знание языка программирования T-SQL nactyx SQL, базы данных 11 09.11.2015 16:49
Team foundation server. Вопрос о check-in,-out,merge Познающий Софт 3 24.11.2013 12:59
вопрос по поводу выбора языка програмирования _ku4er_ Свободное общение 44 16.07.2012 08:41
Изменение языка среды MS SQL Server 2008 virtuhay266 Помощь студентам 1 01.06.2011 02:00


18:47.


Powered by vBulletin® Version 3.8.8 Beta 2
Copyright ©2000 - 2018, Jelsoft Enterprises Ltd.

RusProfile.ru


Справочник российских юридических лиц и организаций.
Проекты отопления, пеллетные котлы, бойлеры, радиаторы
интернет магазин respective.ru