С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/14: Рейтинг темы: голосов - 14, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 06.03.2012
Сообщений: 21
1

Разобраться в синтаксисе update с вложениями

07.03.2012, 08:33. Показов 2928. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите, пожалуйста, написать апдейт
есть временная таблица (подгружается)
необходимо из нее обновлять кол-во в таблицу sklad
временная таблица содержит поля Num, kolvo
связь таблиц spr и sklad на рисунке.

не могу разобраться в синтаксисе update с вложениями

так пишу
SQL
1
UPDATE sklad SET kolvo= (SELECT kolvo FROM temp WHERE r3_num=(SELECT r3_num FROM spr WHERE spr.id=sklad.spr_id)
пишет что запрос должен быть обновляемый . я так понимаю надо использовать оператор INNER JOIN но не могу что-то
написать его
SQL
1
2
3
4
5
UPDATE sklad 
INNER JOIN (temp
INNER JOIN spr  ON spr.id = sklad.id_id_spr) 
     ON temp.r3_num = sklad.r3_num 
    SET sklad.kolvo =temp.kolvo
Ошибка синтаксиса в операции JOIN
Миниатюры
Разобраться в синтаксисе update с вложениями  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.03.2012, 08:33
Ответы с готовыми решениями:

Ошибка в синтаксисе в UPDATE
Выводит следующую ошибку "You have an error in your SQL syntax; check the manual that corresponds...

Ошибка в синтаксисе функции UPDATE
Ошибка в синтаксисе. При передаче данных не видит id

Разобраться в синтаксисе!
Господа помогите пожалуйста разобраться в синтаксисе! Я уже голову сломал. Вот написанный мною же...

Подскажите, почему выдает "Ошибка в синтаксисе UPDATE"?
Подскажите, почему выдает "Ошибка в синтаксисе UPDATE" private void button6_Click(object...

5
Эксперт MS Access
7447 / 4581 / 302
Регистрация: 12.08.2011
Сообщений: 14,288
07.03.2012, 09:20 2
Если r3_num есть в складе, то кузнец (spr) не нужен.

T-SQL
1
2
update sklad inner join  temp ON temp.r3_num = sklad.r3_num 
SET sklad.kolvo = temp.kolvo
0
0 / 0 / 0
Регистрация: 06.03.2012
Сообщений: 21
07.03.2012, 09:43  [ТС] 3
нет r3_num нет, я его добавила хотела сделать сначала update -обновить из spr
но не получилось... (вообщем оно пустое)

Добавлено через 17 минут
получается мне надо один update из двух
SQL
1
2
UPDATE sklad INNER JOIN  spr ON spr.id = sklad.id_spr 
SET sklad.r3_num=spr.r3_num

SQL
1
2
UPDATE sklad INNER JOIN  temp ON temp.r3_num = sklad.r3_num 
SET sklad.kolvo = temp.kolvo
только не обновлять в складе r3_num находить записи по id_spr
думаю меня поняли
0
Эксперт MS Access
7447 / 4581 / 302
Регистрация: 12.08.2011
Сообщений: 14,288
07.03.2012, 09:46 4
тогда так:

T-SQL
1
UPDATE sklad INNER JOIN (spr INNER JOIN temp ON spr.r3_num=temp.r3_num) ON sklad.id_spr=spr.id SET sklad.kolvo = temp.kolvo;
1
0 / 0 / 0
Регистрация: 06.03.2012
Сообщений: 21
07.03.2012, 09:50  [ТС] 5
Спасибо!
0
1180 / 631 / 39
Регистрация: 30.05.2010
Сообщений: 715
08.03.2012, 00:52 6
Здравствуйте 799349.
Увидел в таблице имя поля r3_num, Вы наверное используете данные из SAP R3(?).
Этот факт и имя таблицы sklad говорит о том, что планируется не решение учебной задачи,
а создание конструкции для практического применения.
Если я не ошибся и это действительно так, хочу Вам дать пару советов:
В программах складского учета запросы на обновление (UPDATE...) используются только для служебных целей, таких как:
ревизионная корректировка, корректировка ошибочно введенных данных,...
"..обновлять кол-во в таблицу sklad.." - не верный подход, все действия должны регистрироваться отдельными записями.
1. Для ввода данных используется только добавление (INSERT INTO ...).
Добавление записей прихода на склад и добавление записей расхода со склада.
2. Практически во всех случаях для идентификации записей прихода/расхода ключевого поля ID не достаточно,
для возможности анализа и отбора у записей должен быть атрибут указывающий Дату/Время события,
т.е. присутствие в таблице поля с типом данных ДатаВремя обязательно.

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

Вот такие советы.

Успехов Вам.
Евгений.
2
08.03.2012, 00:52
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.03.2012, 00:52
Помогаю со студенческими работами здесь

Не могу разобраться с UPDATE в SQL
У меня существует база В ней есть: Фамилия, имя, номер, деньги Я добавляю все через Fieldbyname...

DataGrid update ПРОБЛЕМА: Key column information is insufficient or incorect. Too many rows were affected by update
Привет всем ! В Вижуал Басик6 на форме имею ДатаГрид с информацией из Аксцессс 2000. Соединение...

Дедлоки между update limit N и update по primary key
Добрый день! Столкнулся с дедлоками, хотелось бы послушать опытных товарищей как с этим быть. ...

Не получается сделать Update (Update requires a valid InsertCommand)
Не получается сделать Update выдаёт ошибку, что делаю не так? В таблице только одно поле, оно...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru