С Новым годом! Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
9 / 9 / 8
Регистрация: 08.11.2014
Сообщений: 215
Записей в блоге: 1

Изменение поля таблицы на поле из другой таблицы

13.12.2016, 19:54. Показов 3056. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть 2 таблицы: product и prod_type
В первой хранятся продукты, во второй типы продуктов
В первой таблице есть поля p_price, p_type и другие
p_type является вторичным ключом к полю t_id из таблицы prod_type
Во второй таблице есть поле t_price
Цена продукта устанавливается в зависимости от типа продукта
Продукт типа 1 имеет цену 10
Продукт типа 2 имеет цену 15
Это к примеру
Так вот, нужно написать запрос, который и будет устанавливать эту цену
Я знаю как мне узнать сколько будет стоить мой продукт, но я не знаю как мне эту цену назначить
SQL
1
SELECT p_id, t_price FROM product p1, prod_type p2 WHERE p1.p_type = p2.t_id
Пробовал через update, написал так:
SQL
1
UPDATE product SET p_price = (SELECT t_price FROM product p1, prod_type p2 WHERE p_type = t_id)
При выполнении последнего запроса отхвачиваю ошибку, ибо запрос возвращает не одно значение (что логично)
Подскажите, пожалуйста, как мне назначить цену продукта
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.12.2016, 19:54
Ответы с готовыми решениями:

Запрос для вставки данных из поля одной таблицы в поле другой
Подскажите, как с помощью запроса вставить данные из поля Код_квитанции таблицы Квитанции в таблицу Услуги_в_заказе в поле Код_квитанции?

Как в поле ID одной таблицы записать значение поля ID другой таблицы
В БД две таблицы: 1)USERS с полями ID_User, Name, Password. В нее записываются пользователи после регистр-ии. 2)SALES с полями...

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

4
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
13.12.2016, 23:23
после "назначения" цены продукта product.p_price из таблицы prod_type.t_price она ещё будет меняться?
что должно происходить с product.p_price, если изменяется prod_type.t_price?
когда будет выполняться запрос если его напишешь?
0
9 / 9 / 8
Регистрация: 08.11.2014
Сообщений: 215
Записей в блоге: 1
14.12.2016, 00:11  [ТС]
Цитата Сообщение от YuryK Посмотреть сообщение
будет меняться?
Нет, цены меняться не будут
Сначала идёт заполнение таблицы prod_type, потом заполняется product
0
1040 / 856 / 335
Регистрация: 08.12.2016
Сообщений: 3,283
14.12.2016, 00:32
Лучший ответ Сообщение было отмечено avraal как решение

Решение

т.е. product.p_price должна проставляться один раз, при создании записи в product?

тогда логичнее создать триггер

T-SQL
1
2
3
4
5
6
7
8
9
10
CREATE TRIGGER Product_AfterInsert ON dbo.Product
AFTER INSERT
AS
BEGIN
  UPDATE Product SET p_price = prod_type.t_price
  FROM  
   inserted 
  JOIN Product ON inserted.p_id = Product.p_id 
  LEFT JOIN prod_type ON  inserted.p_type = prod_type.t_id
END
1
9 / 9 / 8
Регистрация: 08.11.2014
Сообщений: 215
Записей в блоге: 1
14.12.2016, 00:43  [ТС]
Цитата Сообщение от YuryK Посмотреть сообщение
один раз, при создании записи в product?
Именно
Спасибо за помощь
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.12.2016, 00:43
Помогаю со студенческими работами здесь

Можно ли как нибудь добавить данные из 1 поля 1 таблицы в pickllist другого поля другой таблицы?
Добавить данные в picklist полю ФИО, чтоб получился выпадающий список Бред конечно, ноо... Может есть какие идеи?) ...

Сложить поля в связной таблице и поместить в поле другой таблицы
Доброе время суток. Как с помощью запроса сделать следующее Нужно получить данные по связи, сложить их и засунуть в поле другой...

Сложный запрос? Поля из одной таблицы, и поля из другой таблицы, но...
Вот так мы делаем выборку из основной таблицы table1: SELECT t1.ID, t1.f2, t1.f3 FROM table1 t1 WHERE (какой-то простой фильтр) ...

Переместить два столбца одной таблицы со строкой в поле другой таблицы
Доброго времени суток, добрый форумчанин. Возникла проблема следующего плана: Есть две таблицы: таблица1 (iblock_section_id, id) и...

Внести в поле таблицы сумму значений из другой таблицы по условию
Есть две таблицы данных People (плательщики) и Pays (платежи) Необходимо при занесении нового платежа в таблицу Pays для каждого...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru