Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 13.06.2007
Сообщений: 29

Возможно ли в VB использовать SQL-запросы в которых данные в одной таблице редактируются данными из другой?

26.05.2009, 03:41. Показов 1180. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Возможно ли в VB использовать SQL-запросы в которых данные в одной таблице редактируются данными из другой. Например:

UPDATE customer
SET (address1, address2) =
(SELECT address1, address2
FROM newaddr
WHERE newaddr.customerID=customer.customerID)

В книгах по SQL о таком написано, но по всей видимости в VB-шной интерпретации SQL такое не разрешено.

Или может я ошибаюсь?
Заранее благодарен!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.05.2009, 03:41
Ответы с готовыми решениями:

Как из одной таблицы вытащить данные одной колонки и проставить в другой таблице в oracle?
Мой скрипт везде проставляет одно и то же: update import_data set iin=( select e.iin from zags_2014.existing_persons e where ...

QSqlRelationalTableModel не редактируются данные в таблице
Доброго времени суток. Не получается изменить или удалить данные в QSqlRelationalTableModel //реализация таблицы ...

Как обновить данные одной строки данными из другой?
Есть таблица sales с полями model,color,price.Вытаскиваю данные из строки с id='12' и пытаюсь их вставить с id='13', UPDATE sales SET...

5
0 / 0 / 0
Регистрация: 17.06.2008
Сообщений: 30
26.05.2009, 08:12
читать мануал лучше надо...8)
ЭТО НЕ ПРАЛЬНО!
----------------
UPDATE customer
SET (address1, address2) =
(SELECT address1, address2
FROM newaddr
WHERE newaddr.customerID=customer.customerID)
--------------
А так вот можно...
UPDATE a SET
a.address1=b.address1
a.address2=b.address2
FROM newaddr a, customer b
WHERE a.customerID=b.customerID
0
0 / 0 / 0
Регистрация: 13.06.2007
Сообщений: 29
26.05.2009, 11:40  [ТС]
'мануал' читаю постоянно ;-)
А указанный мной синтаксис один к одному переписан из книги о SQL

К сожалению предложенный вариант также не заработал.
Может с SQL сервер он бы и подошел.
Я работаю с базой Access. Подозреваю что проблема как раз в этом - существуют ограничения или различия для SQL при работе с различными базами данных.
0
Neld
26.05.2009, 12:42
В асексе в дизайнере укажи тип запроса update, свяжи две таблицы и посмотри SQL
IgorB
27.05.2009, 00:56
Update ne mojet rabotat' srazu na 2 kolonki, nado poocheredno:
1)UPDATE a SET a.address1=b.address1 FROM newaddr a, customer b
WHERE a.customerID=b.customerID

Zatem vkluchit' 2 sintaks:

2)UPDATE a SET a.address2=b.address2 FROM newaddr a, customer b
WHERE a.customerID=b.customerID

Eto budet rabotat'.
Igor
0 / 0 / 0
Регистрация: 13.06.2007
Сообщений: 29
27.05.2009, 09:38  [ТС]
К сожалению не один из предложенных SQL запросов не работал в VB с базой Access.

Воспользовался советом Neld - в Access в дизайнере запросов указал тип запроса update, связал две таблицы и посмотрел сгенерированный SQL-запрос.

Получилось следующее:

UPDATE
customer INNER JOIN newaddr
ON customer.customerID = newaddr.customerID
SET customer.address1= [newaddr]![address1]

Проверил - все заработало!
Т.е. оказалось что в запросе на обновление UPDATE вместо имени таблицы нужно записать объединение таблиц JOIN.

Всем большое спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.05.2009, 09:38
Помогаю со студенческими работами здесь

SQL в Delphi. Вывод полей в одной таблице - шапкой в другой.
Привет всем. Есть база данных на Access связанная в делфи через ADOConnection (ADOTable, DataSource, DBGrid и тд ). В акцесе есть...

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

Как данные одной функции использовать в другой?
как сделать так, что бы мои значения, которые посчитаны с помощью одной функции, вызвать в другой ? у меня посчитаны у0,у1,у2,у3. как все...

Как обновить данные в одной таблице, используя поле из другой?
как обновить данные в одной таблице используя поле из другой? update . set Quantity = case when DateofPublish between 2008-01-01 and...

Как использовать возвращаемые данные из одной процедуры в другой процедуре?
Я даже не знаю как тему назвать +) по сути глупый вопрос, но всё же. Есть значит пакет в которм вызываеться процедура LOAD.LOADDATA...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru