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

Вставка в таблицу

02.08.2013, 17:45. Показов 1230. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет.
Очень нужна помощь, разъясните, пожалуйста, в чём может быть проблема.
Имеется 4 таблицы.
table1, столбец Column1
table2, столбцы Column1(значение постоянное) и Column2
table3, столбцы Column1(счётчик) и Column2
table4, столбцы Column1(PK) и Column2(PK)

T-SQL
1
2
3
4
5
INSERT INTO table3(Column2)
OUTPUT INSERTED.Column1 
SELECT t2.Column1 FROM table1 t1, table2 t2 WHERE t1.column1 = t2.Column1
INSERT INTO table4 (Column1, Column2)
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
Запускаю скрипт, он отрабатывает, как надо, с любыми входными данными.
Но при повторном запуске скрипта в 4 строке получаю: Violation of PRIMARY KEY constraint 'PK_table4'. Cannot insert duplicate key in object 'dbo.table4'.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.08.2013, 17:45
Ответы с готовыми решениями:

Вставка в таблицу
Нужно из одной таблицы вставить значения в другую. В процедуру передаются массивы в виде xml: create procedure UpdateEmail @ID int, ...

Вставка в таблицу
Привет всем. Подскажите пожалуйста выполняю вставку в таблицу вот таки запросом: "INSERT INTO users...

Вставка в таблицу
Программно создаю таблицу(В БД нет ни одной таблицы) private void jButton3ActionPerformed(java.awt.event.ActionEvent evt) { ...

11
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
02.08.2013, 17:54
Цитата Сообщение от tapinam Посмотреть сообщение
Violation of PRIMARY KEY constraint 'PK_table4'. Cannot insert duplicate key in object 'dbo.table4
Что именно непонятно в этом сообщении? Вы не знаете что такое PK?
0
21 / 23 / 9
Регистрация: 26.07.2013
Сообщений: 109
02.08.2013, 18:18  [ТС]
Цитата Сообщение от invm Посмотреть сообщение
Что именно непонятно в этом сообщении? Вы не знаете что такое PK?
Это сообщение я понимаю.
Мало данных предоставил.
Я хочу понять из-за чего вылетает этот эксепшн.
В table1 значение Column1 - '1', '2', '3' и т.д.
В table2 значение Column1 - '1', '1', '1' - постоянное, значение Column2 - '11','12','13'.

Попробовал сделать:
T-SQL
1
SELECT TOP 1 t2.Column1 FROM table2 t2
Выводит одну строку в table3 и 3 строки в table4
При повторном запросе выдаёт эксепшн.
Если TOP 1 не делать, то выведет 3 строки в table3 и 9 в table4.
Меня интересует, почему так происходит.


Я новичок в этом, поэтому некоторые вещи могу не увидеть сразу.
Если нужны дополнительные данные - скажите.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
02.08.2013, 18:39
tapinam, выполните дважды
T-SQL
1
2
3
4
INSERT INTO table3(Column2)
SELECT t2.Column1 FROM table1 t1, table2 t2 WHERE t1.column1 = t2.Column1
 
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
И сравните результаты.
1
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
02.08.2013, 21:40
То же, но другими словами :
Для того, чтобы можно было вставить новые значения в таблицу, необходимо чтобы в ней не было строки с таким же РК, как в добавляемых строках. Это обозначает, что пересечение по первичному ключу добавляемых данных с тем, что уже есть в таблице, пусто.
Проверьте это после первого и второго запусков:
T-SQL
1
2
3
select t3.Column1, t2.Column2 from table3 t3, table2 t2 
INTERSECT
select t4.Column1, t4.Column2 from table4 t4
Если в результате пустая выборка, добавлять можно, иначе будет ошибка добавления.
1
21 / 23 / 9
Регистрация: 26.07.2013
Сообщений: 109
05.08.2013, 10:20  [ТС]
Цитата Сообщение от invm Посмотреть сообщение
tapinam, выполните дважды
T-SQL
1
2
3
4
INSERT INTO table3(Column2)
SELECT t2.Column1 FROM table1 t1, table2 t2 WHERE t1.column1 = t2.Column1
 
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
И сравните результаты.
Этот запрос выполняется несколько раз, но мне требуется хранить данные в четвертой таблице, вот в чём проблема.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
05.08.2013, 10:49
tapinam, проблема в том, что вы почему-то считаете, что на момент второго выполнения
T-SQL
1
2
INSERT INTO table4 (Column1, Column2)
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
таблица table4 пустая.
1
21 / 23 / 9
Регистрация: 26.07.2013
Сообщений: 109
05.08.2013, 11:10  [ТС]
Цитата Сообщение от invm Посмотреть сообщение
tapinam, проблема в том, что вы почему-то считаете, что на момент второго выполнения
T-SQL
1
2
INSERT INTO table4 (Column1, Column2)
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
таблица table4 пустая.
Я понял.
А тогда я могу использовать:
T-SQL
1
2
3
4
5
6
7
8
IF NOT EXISTS(
  SELECT t1.Column1, t3.Column2
  FROM table1 t1, table3 t3
  WHERE 
    t1.Column1 = t3.Column2)
BEGIN 
INSERT ...
END
Если уже существует, то не вставлять, правильно?
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
05.08.2013, 11:16
если уж хочется вставлять именно такие данные, то вот правильный (хотя и далеко не оптимальный) запрос:
T-SQL
1
2
3
4
INSERT INTO table4 (Column1, Column2)
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
EXCEPT
select t4.Column1, t4.Column2 from table4 t4
Добавлено через 3 минуты
или, точнее
T-SQL
1
2
3
INSERT INTO table4 (Column1, Column2, Column3) -- PK(Column1, Column2)
SELECT t3.Column1, t2.Column2,t3.Column3 from table3 t3, table2 t2
WHERE NOT EXISTS(select * from table4 t4 where t4.Column1=t3.Column1 and t4.Column2=t2.Column2)
1
21 / 23 / 9
Регистрация: 26.07.2013
Сообщений: 109
05.08.2013, 11:38  [ТС]
Цитата Сообщение от cygapb-007 Посмотреть сообщение
если уж хочется вставлять именно такие данные, то вот правильный (хотя и далеко не оптимальный) запрос:
T-SQL
1
2
3
4
INSERT INTO table4 (Column1, Column2)
SELECT t3.Column1, t2.Column2 from table3 t3, table2 t2
EXCEPT
select t4.Column1, t4.Column2 from table4 t4
Добавлено через 3 минуты
или, точнее
T-SQL
1
2
3
INSERT INTO table4 (Column1, Column2, Column3) -- PK(Column1, Column2)
SELECT t3.Column1, t2.Column2,t3.Column3 from table3 t3, table2 t2
WHERE NOT EXISTS(select * from table4 t4 where t4.Column1=t3.Column1 and t4.Column2=t2.Column2)
Проблема в том, что у меня нет Column3 в таблицах 3 и 4, разве нельзя без них обойтись?
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
05.08.2013, 11:59
tapinam, можно
Это ваши таблицы - делайте с ними все, что нужно именно вам
Я просто показал, как быть, если бы в таблицах были дополнительные поля
1
21 / 23 / 9
Регистрация: 26.07.2013
Сообщений: 109
05.08.2013, 18:23  [ТС]
Всем огромное спасибо за разъяснения.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.08.2013, 18:23
Помогаю со студенческими работами здесь

Копирование и вставка в таблицу
Здравствуйте! Имеется таблица, с целью реализации свободного заполнения ячеек которой используется <td>text</td>. Проблема...

Вставка в таблицу данных по их ID
Здравствуйте! Помогите пожалуйста решить задачу! Есть три таблицы: абоненты, города, улицы. В таблице абонентов хранятся поля CityID,...

Вставка строки в таблицу
Подскажите пожалуйста, как реализовать следующую функцию: Имеем в файле MS Excel 2010 таблицу, названную "Таблица1" Нижняя...

Вставка формы в таблицу (IE)
Возникла необходимость вставить форму в таблицу. Так вот, в Опере все выглядит замечательно, а в IE после формы добавляется пустая строка....

Вставка 3 записей в таблицу
помогите,вставить 3 строки,2 вставляет а 3ью - нет. https://yadi.sk/d/WF0xXWWP3HCRvF


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru