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

Почему в запросе с несколькими insert добавляются не все данные?

27.02.2019, 15:44. Показов 587. Ответов 1

Студворк — интернет-сервис помощи студентам
Всем привет!

Пишу такой запрос:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
UPDATE mst_produce_order_struct
SET OdinAssID = 6492019
   ,Name = '02-01 СГП Комоды дуб сонома ч.2'
   ,IsEmpty = 0
   ,Employee = 41
WHERE OrderID = 18
AND IsEmpty = 1;
IF @@rowcount = 0
  INSERT INTO mst_produce_order_struct (OrderID, OdinAssID, Name, MONTH, Num, Employee, Comment)
    VALUES (18, 6492019, '02-01 СГП Комоды дуб сонома ч.2', 2, 1, 41, '');
UPDATE mst_produce_order_struct
SET OdinAssID = 6502019
   ,Name = '02-01 Комоды венге ч.1'
   ,IsEmpty = 0
   ,Employee = 41
WHERE OrderID = 18
AND IsEmpty = 1;
IF @@rowcount = 0
  INSERT INTO mst_produce_order_struct (OrderID, OdinAssID, Name, MONTH, Num, Employee, Comment)
    VALUES (18, 6502019, '02-01 Комоды венге ч.1', 2, 1, 41, 'Света');
UPDATE mst_produce_order_struct
SET OdinAssID = 6512019
   ,Name = '02-01 СГП Комоды венге ч.2'
   ,IsEmpty = 0
   ,Employee = 41
WHERE OrderID = 18
AND IsEmpty = 1;
IF @@rowcount = 0
  INSERT INTO mst_produce_order_struct (OrderID, OdinAssID, Name, MONTH, Num, Employee, Comment)
    VALUES (18, 6512019, '02-01 СГП Комоды венге ч.2', 2, 1, 41, 'пн');
--etc
В тестовом запросе 55 строк должно добавиться. Ответ по количеству затронутых строк от базы приходит 55.
По факту добавляется 27 строк. Сравнила результат добавления с запросом, оказалось, что чётные строки почему-то пропускаются, но при повторном исполнении запроса добавляется всё остальное.

Я бы могла оставить этот костыль, но боюсь, что лучше понять куда смотреть, чтобы подобное не повторилось.

Заранее спасибо за ответы
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.02.2019, 15:44
Ответы с готовыми решениями:

Почему то не добавляются данные в БД
Есть форма и обработчик. В обработчике не проходит условие и пишет что не все поля заполнены. подскажите, плз, в чем ошибка. Форма: ...

Почему не добавляются данные в базу
Ребят, подскажите начинающей. Вот код: sqlConnection1.Open(); SqlTransaction trans =...

Почему не добавляются данные из формы в базу данных?
Я начинающий в этом деле, поэтому подскажите, пожалуйста. У меня есть код и вроде он работал, то есть через форму осуществлялось добавление...

1
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
27.02.2019, 17:43
Что бы понять, добавьте до и после каждого update: select * from mst_produce_order_struct where OrderID = 18 and IsEmpty = 1
Или задайте себе волпрос: "Что получтится, если на момент первого update в таблице будет несколько строк для OrderID = 18 с IsEmpty = 1?

Если хотите заставить работать этот ужас, то пишите UPDATE top (1) mst_produce_order_struct ...

Или перепишите по-человечески. Например, так:
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
declare @OrderId int = 18;
 
with s as
(
 select
  a.OdinAssID, a.Name, a.MONTH, a.Num, a.Employee, a.Comment,
  row_number() over (order by 1/0) as rn
 from
  (
   values
    (6492019, '02-01 СГП Комоды дуб сонома ч.2', 2, 1, 41, ''),
    (6502019, '02-01 Комоды венге ч.1', 2, 1, 41, 'Света'),
    (6512019, '02-01 СГП Комоды венге ч.2', 2, 1, 41, 'пн')
  ) a(OdinAssID, Name, MONTH, Num, Employee, Comment)
),
t as
(
 select
  OrderID, OdinAssID, Name, MONTH, Num, Employee, Comment, IsEmpty,
  row_number() over (order by 1/0) as rn
 from
  mst_produce_order_struct
 where
  OrderId = @OrderId and
  IsEmpty = 1
)
merge into t
using s on s.rn = t.rn
when matched then
 update
  set
    OdinAssID = s.OdinAssID,
    Name = s.Name,
    IsEmpty = 0,
    Employee = s.Employee
when not matched then
 insert
  (OrderID, OdinAssID, Name, MONTH, Num, Employee, Comment)
 values
  (@OrderID, s.OdinAssID, s.Name, s.MONTH, s.Num, s.Employee, s.Comment);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.02.2019, 17:43
Помогаю со студенческими работами здесь

Почему в запросе Query1 неправильно суммируются данные?
почему в ЗАПРОСЕ Query1 НЕ СУММИРУЮТСЯ ДАННЫЕ ПРАВИЛЬНО? заранее спасибо

Insert из нескольких программ, инкремент растет, а некоторые записи не добавляются
Добрый день уважаемые форумчане подскажите пожалуйста. Один раз в пять минут из нескольких программ (9 штук) делаю INSERT в одну базу...

Не обновляются/добавляются данные данные через клиент
привет форумчане,не обновляются данные через клиент при нажатии на кнопку ничего не происходит form1.cs using System.Data; using...

Ошибка в запросе INSERT
INSERT INTO Forms..(Наименование) VALUES (Forms..Наименование);

Ошибка в Insert запросе
http://floomby.ru/s1/yahA3b Доброй ночи, уважаемые форумчане, требуется ваша помощь. Текст процедуры таков, выдается ошибка (скрин...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка 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 и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru