Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752

Доработка SQL-запроса вновь

12.09.2017, 11:26. Показов 689. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, господа. Подобная тема поднималась на форуме, но там не совсем то, что мне нужно. Необходимо выполнить update таблицы выборкой из двух других. Сама выборка работает:
SQL
1
2
SELECT GUsers.TNUM, GUsers.Tarif FROM GUsers WHERE GUsers.ID_Fil=2 AND EXISTS 
(SELECT pow_id FROM powperiod WHERE pactive=1 AND pn='I-80/2017' AND GUsers.ID=PowPeriod.Pow_ID)
а вот update
SQL
1
2
3
UPDATE staff SET PrN=(SELECT GUsers.TNUM, GUsers.Tarif FROM GUsers WHERE GUsers.ID_Fil=2 AND EXISTS 
(SELECT pow_id FROM powperiod WHERE pactive=1 AND pn='I-80/2017' AND GUsers.ID=PowPeriod.Pow_ID))
WHERE staff.tnum=GUsers.tnum
ругается Сообщение 4104, уровень 16, состояние 1, строка 4Не удалось привязать составной идентификатор "GUsers.tnum".
Убираю where ругается: Сообщение 116, уровень 16, состояние 1, строка 3
В списке выбора можно указать только одно выражение, если вложенный запрос не предварен EXISTS
Что я делаю не так?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.09.2017, 11:26
Ответы с готовыми решениями:

Доработка SQL-запроса
Добрый день, господа. Прошу Вашей помощи в доработке запросов. Дело в том, что когда писались (и благодаря Вашей помощи тоже) эти запросы...

Доработка запроса SQL
Есть запрос: SELECT Gorod.Nazvanie_Goroda, Organization.Nazvanie_Organization, Abonent.Phone_Abonenta FROM и так далее... Как...

Доработка SQL-запроса
Доброго дня, господа форумчане. Получилась у меня такая вот задачка - выбрать одно поле из двух таблиц по условию. Есть два справочника...

6
 Аватар для ZfoxAK
670 / 560 / 242
Регистрация: 26.11.2012
Сообщений: 2,191
12.09.2017, 11:53
Цитата Сообщение от drvolodko Посмотреть сообщение
PrN=(SELECT GUsers.TNUM, GUsers.Tarif
Одно поле слева, два справа - это так и нужно?
0
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752
13.09.2017, 08:43  [ТС]
Воу Чет совсем и не посмотрел Селект работает, значит типа и апдейт пройдет Спасибо попробую

Добавлено через 11 часов 54 минуты
нет, не работает. При where ошибка та же самая. А если убрать условие, то возвращается более одного значения, что тоже генерит ошибку. В принципе, пофиг. Я update в цикле организовал, просто хотел одним махом обновить таблицу.
0
5978 / 4553 / 1095
Регистрация: 29.08.2013
Сообщений: 28,180
Записей в блоге: 3
13.09.2017, 09:36
Цитата Сообщение от drvolodko Посмотреть сообщение
update в цикле организовал
только не делай такое больше и не показывай никому
0
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752
14.09.2017, 08:56  [ТС]
qwertehok, это понятно, но разве у меня есть другие варианты в данном конкретном случае в текущий момент истории?
0
5978 / 4553 / 1095
Регистрация: 29.08.2013
Сообщений: 28,180
Записей в блоге: 3
14.09.2017, 09:20
конечно есть
сесть, подумать головой и переписать запрос на правильный
0
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752
14.09.2017, 16:45  [ТС]
Я и спросил на форуме, потому что ошибку не вижу вроде все правильно и логично...
SQL
1
2
3
UPDATE staff SET PrN=(SELECT GUsers.Tarif FROM GUsers WHERE GUsers.ID_Fil=2 AND EXISTS 
(SELECT pow_id FROM powperiod WHERE pactive=1 AND pn='I-80/2017' AND GUsers.ID=PowPeriod.Pow_ID))
WHERE staff.tnum=GUsers.tnum
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.09.2017, 16:45
Помогаю со студенческими работами здесь

2 Запроса: SQL
Здравствуйте. Помогите сделать два запроса SQL в делфи у компонентов ADOQuery. 1) сколько больных было принят в поликлинике и на дому...

Выборка из sql-запроса
Есть текст SQL-запроса, он большой, там select 20 полей, вложенные запросы, формируется по условиям в зависимости от выбранных...

Ошибка запроса SQL
Добрый день. Пытаюсь выполнить запрос на выборку из двух таблиц, но вылетает ошибка. with DMF.AResult do begin close; ...

Выполнение запроса sql
При экспорте или при выполнение запроса, если имя фотографии повторяется(поле ph.naimphoto), его не выводит. В коде вроде этого не...

Выполнение sql запроса
Доброго времени суток! Проблема в следующем: у меня есть грид, в котором отражены данные о владельцах автомобилей. Данные хранятся в субд...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru